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1. The designated Office is hereby notified of its election made: j 
|~X] m the demand filed with the International preliminary Examining Authority on: 

25 November 2000 (25.11.00) 

| | in a notice effecting later election filed with the International Bureau on: 



2. The electio 



n [Xl 
□ 



was 



was not 



made before the expiration of 19 months from the priority date or, w 
Rule 32.2(b). 



here Rule 32 applies, within the time limit under 



ics i mi 



The International Bureau of WIPO 
34, chemin des Colombettes 
121 1 Geneva 20, Switzerland 

e No.: (41-22) 740.14.35 



Authorized officer: 

J. Zahra 

Telephone No.: (41-22) 338.83. 38 



Form PCT IB 331 (July 1992) 



3912356 



VERTRAG ttR DIE INTERNATIONALE ZUS/jA 

1 .•dem gebiet des p at e nt w eI^Fj 




ENARBEIT 

IS 



PCT 



INTERN ATIONALER RECHERCHENBERICHT 

(Artikel 18 sowie Regeln 43 und 44 PCT) 



Aktenzeichen des Anmelders oder Anwalts 

P61 . 12PCT227 



Internationales Aktenzeichen 

PCT/EP 00/07622 



WEITERES 
VORGEHEN 



siehe Mrtteilung uber die Ubermrttlung des mternationalen 
Recherchenberichts (Formblatt PCT/ISA/220) sow.e, soweit 
zutreffend, nachstehender Punkt 5 



Internationales Anmeldedatum 
(Tag/Monat/Jahr) 

05/08/2000 



(Fruhestes) Prioritatsdatum (Tag/Monat/Jahr) 

22/09/1999 



Anmelder 



PAPST-M0T0REN GMBH & CO KG 



Dieser internat.onale Recherchenbench, wurde von der -n.erna.iona^n Recherchenbeh6rde erstelN und wird den, Anmelder gemaB 
Artikel 18 ubermittelt. Eine Kopie wird dem mternationalen Buro ubermrttelt. 

Grundlage des Berlchts 

n Die internat t ona,e Recherche is, auf der Grundlage einer bei der Behorde e.ngereichten Obersetzung der in,erna„ona,en 
1 — 1 Anmeldung (Regel 23.1 b)) durchgefiihrt worden. 
b Hins 1C h,„ch der in der international Anmeldung oHenbarten Nuc.eot.d- undfeto Am.nosaureseguenz is, d,e in,erna,ona,e 
Recherche auf der Grundlage des Sequenzprotokolls durchgefuhrt worden. das 
r~| in der internationalen Anmeldung in Schritlicher Form enthalten ist. 

zusammen mit der internationalen Anmeldung in computerlesbarer Form eingere.cht worden ist. 
bei der Behorde nachtraglich in schrittlicher Form eingereicht worden ist. 
bei der Behorde nachtraglich in computerlesbarer Form eingereicht worden ist. 

Die Erklarung. daB das nachtragNch eingereichte schrrftliche Sequenzprotokoll nich. uber den Offenbarungsgehal, der 
internationalen Anmeldung im Anmeldezeitpunkt hinausgeht. wurde vorgelegt. 
□ Die Erklarung. daB die in computerlesbarer Form ertaBten Informahonen dem schriftlichen Sequenzprotokoll entsprechen. 
wurde vorgelegt. 



□ 
□ 
□ 
□ 



2. 
3 



□ Bestlmmte Anspriiche haben slch als nlcht recherchierbar erwlesen (s.ehe Feld I) 
Q Mangelnde Elnheltllchkeit der Erflndung (siehe Feld II). 

Hinsichtlich der Bezeichnung der Erflndung 

[X] w.rd der vom Anmelder eingereichte Wortlaut genehmigt. 
| | wur de der Wortlaut von der Behorde wie folgt festgesetzt: 



Hinsichtlich der Zusammenfassung 

rm wird der vom Anmelder eingereichte Wortlaut genehmigt 

H 1 wnrtiA.it nach Reael 38 2b) in der in Feld III angegebenen Fassung von der Behorde festgesetzt. Der 
n Anme e .d d e e r r ^nn der ^2^1^22 ernes Monats nachV'm Datum der Absendung dieses mternationalen 
1 — 1 Recherchenberichts eine Stellungnahme vorlegen 



Folgende Abb.ldung der Zelchnungen ist m.t der Zusammenfassung zu veroffentlichen: Abb Nr. 
|Xj wie vom Anmelder vorgeschlagen 

| | w eil der Anmelder selbst keine Abbildung vorgeschlagen hat 
| [ weil diese Abbildung die Edindung besser kennzeichnet. 



1 

□ 



keine der Abb. 



Formblatt PCT ISA/2 10 (Blatt 1) (Juli 1998) 



INTERN ATIONALER RECHERCHENBERICHT 




lnte^»!lonales Aktenzeichen 

r^P>P 00/07622 



A. KLASS1FIZIERUNGDESANMELDUNGSGEGENSTANDES n?pfi/n o 

IPK 7 G01P3/489 H02P5/50 HU^ro/uo 



Nach der Intemationden Pa tentklassifkaf on (IPK, ode, nach der nat.onalen Klass.likal.on und der IPK 
B REC HERCHIERTE GEBIETE 

R^ner.-h.eder Mindestprutstott (Klass.f.kat.onssystem und Klassifikationssymbole ) 

IPK 7 G01P H02P 



Recherchierte aber mcht zum Mindes 



? stprOtstott gehorende Veroffentlichungen. soweit diese unter die recnerchierten Gebsete fallen 



Wahrend der intemationalen Recherche konsultierte elektronische 

EPO-Internal , WPI Data, PAJ 



Datenbank (Name der Datenbank und evtl. verwendete Suchbegnffe) 



C. ALS WESENTLICH ANGESEHENE UNTERLAGEN 



Kategone' 



Beze,chnung der Veroffentlichung. sowe,. ertorderiich unter Angabe der ,n Be.rach, kommenden Telle 

US 4 788 476 A (GINIER AMI) 
29 November 1988 (1988-11-29) 
Spalte 3, Zeile 27 -Spalte 4, Zeile 19 
Spalte 5, Zeile 10 - Zeile 47; Abbildungen 

US 4 584 528 A (0HMAE TSUT0MU ET AL) 
22. April 1986 (1986-04-22) 

Spalte 2, Zeile 53 -Spalte 3, Zeile 56; 
Abbi ldung ID 

GB 2 192 103 A (EATON CORP) 
31 Dezember 1987 (1987-12-31) 
Seite 2, Zeile 22 - Zeile 50 
Seite 2, Zeile 66 -Seite 3, Zeile 27; 
Abbildungen 1,2C,D 

_/__ 



Welte re Veroffentlichungen stnd der Fortsetzung von Feld C zu 
entnehmen 

" Be^ondere Kategonen von angegebenen Veroffentlichungen 
"A" Veroffentlichung. die den allgemeinen Stand der Technik defmiert. 

aber nicht als besonders bedeutsam anzusehen ist 
"E" alteres Dokument. das jedoch erst am oder nach dem intemationalen 

Anmeldedatutn verotfentlicht worden ist 
"I " Veroffentlichung die gee.gnet ist. e.nen Priontatsanspruch , zweifelhaft er- 
1 V *che* e zu lassen ode durch die das Veroffentlichungsdatum einer 

'^^^im^^hertendhX genannten Veroffentlichung belegt werden 

soJ 7,Z die aus e,nem anderen besonderen Grund angegeben ,st (w,e 

ausgefuhrt) 

-O" Veroffentlichung. die s.ch auf eine mundhche OHentarung 

e,ne Benutzunq. eine Ausstellung oder andere MaBnahn j«i bezieht 
■p- Ver^eXhu.^ 9 die vor dem intemationalen Anmeldeda turn, aber nach 
dem beanspruchten Pnontatsdatum verotfentlicht worden ist 



Siehe Anhang Patentfamilie 



Betr. Anspruch Nr 

1-4,29, 
30 



1-6,17, 

21,29, 

34,36 



1,5,17, 
21,30,34 



T- Spatere Veroflenthchung. die nach dem ,nternat,.>nalen Anmeldedatum 
ndefdem Pnnnlatsdatum verotfentlicht worden ist und m,t der 
Anmeldung nicht kollidert, sondem m,r rum Verstandnis des der 
e2*X 'zugrundeliegenden Pn.v.p, oder der ,hr zugrundel.egenden 
Theone angegeben ist , iinn 

"X" Veroffentlichunq von besonderer Bedeutung; die beanspruchte Erfindung 

X ^nr ^TSgn?nd dieser Verotfenthchung mcht als neu oder auf 
erfindenscher Tatigkeit heruhend betrachtet werden 

"Y" Veroffentlichung von besonderer Bedeutung; die bear^ruchte Erfindung 
kinn nicht als auf erfindenscher Tatigkeit beruhend betrachtet 
werden I n die Veroffentlichung m.t emer oder mehreren anderen 
V^ro«™t«en dieser Kategone m Verbindung gebracht w.rd und 
diese Verbindung fur emen Fachmann naheliegend ist 

"&■' Veroffentlichung, die Mitglted derselben Patentfamilie ist 



Datum des Abschlusses der intemationalen Recherche 

7. November 2000 



1 



Name und Postanschnft der Intemationalen Recherchenbehorde 
Eumpaisches Patentamt. P.B 5818 Patentlaan 2 
Nl - 2280 HV Rijswi|k 

Tel (+31-/0)340-2040. Tx 31 651 epo nl. 
Fax: (4-31 70) 340-3016 



Absendedatum des intemationalen Rech^chent^nchts 



21/11/2000 



Bevollmachtigter rWinwM»>r 



Pf 1 ugfelder , G 



Formhl-itt P r 1 l^A. MO i Wart .Mi- lull 1*h.M 
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INTERN ATIONALER RECHERCHENBERICHT 



F0:P 00/07622 



C (FortseBung) ALS WESENTLICH A NGESEHENE UNTERLAGEN _ 

Beze,ch.„„ ig de, V^ntUchung. s-^t e rio.deh.ch ^ Angab. der ,n ie.rach, K, OT menden Te„e 



1 



US 5 502 376 A (BUSCH FREDERICK J) 

26 Marz 1996 (1996-03-26) 

Spalte 4, Zeile 28 - Zeile 51 

Spalte 5, Zeile 37 - Zeile 60; Abbildungen 

US 5 237 521 A ( RAJ GURU B ET AL) 
17 August 1993 (1993-08-17) 
Spalte 3, Zeile 24 - Zeile 45 



Betr. Anspruch Nr. 



1,5,17, 
21,30,34 



1,5,17, 
21,30,34 



formhl/itt pr;nSA.M'"WFort-.Ht7iin.i ,nn Rlatt.'i ■ luh 1'' ,J -'> 



Seite 2 von 2 



INTERNATIONAL SEARCH REPORT 

kon patent family members 



Infor 




Patent document 
cited in search report 



US 4788476 



Intentional Application No 

P 00/07622 



ntej^tflof 



Publication 
date 



Patent family 
member(s) 



29-11-1988 



CH 670971 A 

DE 3761290 D 

EP 0263947 A 

JP 63099124 A 



Publication 
date 



31-07-1989 
08-02-1990 
20-04-1988 
30-04-1988 



US 


4584528 


A 


22- 


04- 


1986 


JP 
DE 
EP 


57144465 

3278823 
0059433 


A 
D 
A 


01-09- 
08-09- 


1988 
1982 


GB 


2192103 


A 


31- 


-12- 


•1987 


US 
CA 


4800508 
1296764 


A 
A 


03-03- 


-1992 






A 


26- 


-03- 


-1996 


NONE 














A 


17- 


-08- 


-1993 


JP 


4255867 


A 







Form prj ISA itvitMnt (.iinttv .innHm ..iuly 1 wU '' 





VERTRAG UBER ^INTERNATIONALE ZUSAI^NARBEIT AUF DEM 

GEBIET DES PATENTWESENS 1=017 LZZ 2C01 I 



PCT — 

INTERNATIONAL^ VORLAUFIGER PRUFUNGSBERICHJ_ 

(Artikel 36 und Regel 70 PCT) I j H~ 



Aktenzeichen des Anmelders oder Anwalts 
P61.12PCT227 



Internationales Aktenzeichen 
PCT/EP00/07622 



siehe Mitteilung uber die Ubersendung des internationalen 
WEITERES VORGEHEN vorlaufigen Prufungsberichts (Formblatt PCT/IPEA/416) 



Internationales Anmeldedatum (Tag/Monat/Jahr) 
05/08/2000 



Prioritatsdatum (Tag/Monat/Tag) 
22/09/1 999 



Internationale Patentklassifikation (IPK) oder nationale Klassifikation und IPK 
G01P3/489 



L 



Anmelder 

PAPST-MOTOREN GMBH & CO KG 



1 — eser internationa , e vorlaufige Prufungsbericht wurde von der mit der internationalen vorlaufigen Prufung beauftragten 
Behorde erstellt und wird dem Anmelder gemaB Artikel 36 ubermittelt. 

2. Dieser BERICHT umfaRt insgesamt 5 Blatter einschliefBlich dieses Deckblatts. 

n * o * v mn H Qm Rorirht ANl AGEN bei- dabei handelt es sich urn Blatter mit Beschreibungen, Anspruchen 

Beh^e vo%enTmenen Berichtigungen (siehe Regel 70.16 und Abschnitt 607 der v e rwa.tungsncht.,n,en zum PCT). 
Diese Anlagen umfassen insgesamt Blatter. 



3. Dieser Bericht enthalt Angaben zu folgenden Punkten: 



I 




II 


□ 


III 

IV 


s 

□ 


V 




VI 


□ 


VII 


□ 


VIII 


□ 



Grundlage des Berichts 
Prioritat 

Keine Erstellung eines Gutachtens uber Neuheit, erfinderische Tatigkeit und gewerbliche Anwendbarkeit 
Mangelnde Einheitlichkeit der Erfindung 

Bearundete Feststellung nach Artikel 35(2) hinsichtlich der Neuheit. der erfinderischen Tatigke.t und der 
glwerbSen Anwendbirkeit; Unterlagen und Erklarungen zur Stutzung d.eser Feststellung 

Bestimmte angefuhrte Unterlagen 

Bestimmte Mangel der internationalen Anmeldung 

Bestimmte Bemerkungen zur internationalen Anmeldung 



Datum der Einreichung des Antrags 



25/11/2000 



Name und Postanschrift der mit der internationalen vorlaufigen 
Prufung beauftragten Behorde: 

x Europaisches Patentamt 
sjjh D-80298 Miinchen 

JSP' Tel. +49 89 2399 - 0 Tx: 523656 epmu d 
Fax: +49 89 2399 - 4465 



Datum der Fertigstellung dieses Berichts 
13.12.2001 

Bevollmachtigter Bediensteter 

Koeck, A 

Tel. Nr. +49 89 2399 2493 




Formblatt PCT/I PEA/409 (Deckblatt) (Januar 1994) 



INTERNATIONALER VORLAUFIGER 
PRUFUNGSBERICHT 



Internationales Aktenzeichen PCT/EP00/07622 



I. Grundlage des Berichts 

1 Hinsichtlich der Bestandteile der internationalen Anmeldung (Ersatzblatter, die dem Anmeldeamt auf eine 
' Artikel U Nn vorgelegt warden, gelten im Rabmen dieses 

eZereichrund sind ihm nicht beigefugt, weil sie keine Anderungen enthalten (Regeln 70. 16 und 70. 1 7)). 

Beschreibung, Seiten: 



1_55 ursprungliche Fassung 

Patentanspruche, Nr.: 

-1.41 ursprungliche Fassung 

Zeichnungen, Blatter: 

1/27-27/27 ursprungliche Fassung 



? Hinsichtlich der Sprache Alle vorstehend genannten Bestandteile standen der Behorde in der Sprache, in der 

2 die tntS eingereicht worden ist, zur VerfQgung oder wurden in dieser e.ngere.cht, sofern 
unter diesem Punkt nichts anderes angegeben ist. 

Die Bestandteile standen der Behorde in der Sprache: zur Verfugung bzw. wurden in dieser Sprache 
eingereicht; dabei handelt es sich urn 

□ die Sprache der Ubersetzung, die fur die Zwecke der internationalen Recherche eingereicht worden ist (nach 
Regel 23.1(b)). 

□ die Verbffentlichungssprache der internationalen Anmeldung (nach Regel 48.3(b)). 

□ die Sprache der Ubersetzung, die fur die Zwecke der internationalen vorlaufigen Prufung eingereicht worden 
ist (nach Regel 55.2 und/oder 55.3). 

3 Hinsichtlich der in der internationalen Anmeldung offenbarten Nucleotid- und/oder Aminosauresequenz ist die 

Internationale Z feffige Prufung auf der Grundlage des Sequenzprotoko.ls durchgefuhrt worden, das: 

□ in der internationalen Anmeldung in schriftlicher Form enthalten ist. 

□ zusammen mit der internationalen Anmeldung in computerlesbarer Form eingereicht worden ist. 

□ bei der Behorde nachtraglich in schriftlicher Form eingereicht worden ist. 

□ bei der Behorde nachtraglich in computerlesbarer Form eingereicht worden ist. 

□ Die Erklarung, da(3 das nachtraglich eingereichte schriftliche Sequenzprotokoll nicht uber den 
Offenbarungsgehalt der internationalen Anmeldung im Anme.dezeitpunkt hinausgeht, wurde vorgelegt. 

□ Die Erklarung, da(3 die in computerlesbarer Form ertassten Informationen dem schriftlichen 
Sequenzprotokoll entsprechen, wurde vorgelegt. 

4. Aufgrund der Anderungen sind folgende Unterlagen fortgefallen: 



Formblatt PCT/IPE/V409 (Felder l-VIII. Blatt 1) (Juli 1998) 



INTERNATIONALER VORLAUFIGER 
PRUFUNGSBERICHT 



Internationales Aktenzeichen PCT/EP00/07622 



□ Beschreibung, Seiten: 

□ Anspruche, Nr.: 

□ Zeichnungen, Blatt 

elngereichten Fassung hinausgehen (Regel 70.2(c)). 

(Auf Ersatzbtatter, die sCche Anderungen enttelten, ist unter Pun* 1 ninzu W eisen;sie sind dieserr, Bericnt 
beizufugen). 

6. Etwaige zusatzliche Bemerkungen: 

„, Keine ErsteMung eines Gutachtens uber Neuheit, erfinderische Tatigkeit und gewerb.iche Anwendbarkeit 

, ' p m.ndP Teile der Anmeldung wurden nicht daraufhin gepruft, ob die beanspruchte Erfindung als neu, auf 
1 • SS^r T^ft b^hJnd (nicht offensichtlich) und gewerblich anwendbar anzusehen .st. 

□ die gesamte international Anmeldung. 
B Anspruche Nr. 1 -28,30-41 . 

Begrundung: 

(genaue Angaben): 

werden konnte (genaue Angaben): 
siehe Beiblatt 

□ Die Anspruche bzw. die obengenannten Anspruche Nr. sind so unzureichend durch die Beschreibung 
gestutzt, da(3 kein sinnvolles Gutachten erstellt werden konnte. 

□ Fur die obengenannten Anspruche Nr. wurde kein international Recherchenbericht erstellt. 
entspricht: 

□ Die schriftliche Form wurde nicht eingereicht bzw. entspricht nicht dem Standard. 

□ Die computerlesbare Form wurde nicht eingereicht bzw. entspricht nicht dem Standard. 



Formblatt PCT/IPEA/409 (Felder l-VIII. Blatt 2) (Juli 1998) 



INTERN ATIONALERVORLAUFIGER , nternatjonales Akte nzeichen PCT/E POO/07622 
PRUFUNGSB ERICHT — 

. MiM «, 2 * h insichtlich der Neuheit, der erfinderischen Tatigkeit und der 



1. Feststellung 

kl . ., , KU Ja: Anspruche 

Neuheit (N) . -„u« o Q 

Nein: Anspruche 29 

Erlinderische TaigKei, ,ED ^ Anspruche ^ 

eewe^che A™endbar« (OA) Jj^ ££0*. 2. 



2. Unterlagen und Erklarungen 
siehe Beiblatt 



Formblatt PCT/IPEA/409 (Felder l-VIII. Blatt 3) (Juli 1998) 



INTERNATIONALER VORLAUFIGER 
PRI1FUNGSBERICHT - BEIBLATT 



Internationales Aktenzeichen PCT/E POO/07622 



III. Kpine Erste il'ing eines Gutachtens 

Nach Artikel 6 PCT sind die Anspruche klar und knapp zu fassen. In der 
vorliegenden Anmeldung beinhalten jedoch die Anspruche 1,17,21, 29, 30 und 
34 ungerechtfertigte Textwiederholungen, womit die Erfordernis von Knappheit 
nicht erfullt ist. In der vorliegenden Anmeldung erscheint nur ein unabhang.ger 
Verfahrens- und ein unabhangiger Vorrichungsanspruch zweckmaBig. Nur 
Anspruch 29, der den breitesten Schutzumfang aufweist, wird deshalb gepruft. 

V. Ffiststellun g nach Artikel 35(2) 
1 Es wird auf folgendes Dokument verwiesen: 
D1 = US-A-4 788 476 



2. Artikel 33(2) (Neuheit) 

Ein Motor ist aus D1 bekannt (Fig. 2, (13)), bei welchem die Drehzahl durch ein 
Sollwertsignal in Form einer Frequenz dadurch auf Null regelbar ist, da(3 d.esem 
Sollwertsignal der Frequenzwert Null gegeben wird (R.P.M. Regulator (16)). 
Ublicherweise wird, was auch die Anmelderin nicht bestreitet, ein analoges Signal 
zur Regelung eines Motors (13) verwendet, und ein analoges Signal wird vom 
Tachogenerator ausgewertet. Der Pulsgeber (14) dient dazu, dieses analoge 
Signal als digitales Signal an den Computer (32) weiterzuleiten. Zudem ersche.nt 
es logisch daR, wenn der Motor auf Null herab geregelt werden soli, auch der 
Frequenzwert des Reglungssignal auf Null gestellt wird, da z.B. ein Wert groRer 
als Null auch eine negative Rotation des Motors bewirken konnte. 

Anspruch 29 erfullt somit nicht die Erfordernisse des Artikels 33(2) PCT in bezug 
auf Neuheit. 

3 Artikel 33(4) PCT (Gewftrbliche An wendbarkeif 

Eine gewerbliche Anwendbarkeit wird zur Steuerung von Motoren als gegeben 
betrachtet. 



Formblatt PCT/Beiblatt/409 (Blatt 1) (EPA-April 1997) 




PATENT COOPERATION TRWV 

PCT 

INTERNATIONAL PRELIMINARY EXAMINATION REPORT ^ 

/ 

(PCT Article 36 and Rule 70) *h 



Applicant's or agent's file reference 

P61.12PCT227 



c Tr-.ncmiTt'il of International 
See Notification of Transmittal oi l 

FOR FURTHER ACTION p relimma ry Examination Report (Form PCT.IPbA.4ioi 



International application No. 

PCT/EPOO/07622 



International filing date {day/month/year) 

05 August 2000 (05.08.00) 



Priority date {day. month/year) 

22 September 1999 (22.09.99) 



International Patent Cla>si 
GO IP 3/489 



fication (IPC) or national classification and IPC 



Applicant 



PAPST-MOTOREN GMBH & CO. KG 



"~ . a k„ thi* International Preliminary Examining 



This REPORT consists of a total of 



sheets, including this cover sheet. 



These annexes consist of a total of sheets - ' • 

This report contains indications relating to the following items: 



v.. ' 



Basis of the report . 

II I I PnoHty \ 

— a trt n.v P ltv inventive step and industrial applicability 

ni Q Non-establishment of opinion with regard to novelty, inventive, p 

Lack of unity of invention 

a AfrW with reeard to novelty, inventive step or industrial applicability; 
Reasoned statement under Article 35(2 ) w ith regara^o 
citations and explanations supporting such statement 

Certain documents cited 
Certain defects in the international application 
Certain observations on the international application 



Date of submission of the demand 

25 November 2000(25.11.00) 



Name and mailing address of the IPEA EP 

Facsimile No. 
Form PCT IPEA 409 (cover sheet) (January 1994) 



Date of completion of this report 

13 December 2001 (13.12.2001) 



Authorized officer 



Telephone No. 





INTERNATIONAL PRELIMINARY EXAMINATION REPORT 



PTtemational application No. 

PCT/EP00/07622 



1. Basis of the report 

•v . 



under Article 14 are referred to in this report as ongmalh filed 



the international application as originally filed. 

1-55 , as originally filed, 

, filed with the demand, 

, filed with the letter of 

, filed with the letter of 



□ 

Q~j the description, pages 



□ 



the claims, 



the drawings, 



sheets/fig 
sheets/fig 
sheets/ fig 
sheets/fig 



1-41 



1/27-27/27 



2. The amendments have resulted in the cancellation of: 

j | the description, pages . 

| | the claims, Nos. 



| | the drawings, sheets/fig 



, as originally filed, 

, as amended under Article 19, 

, filed with the demand, 

filed with the letter of 

filed with the letter of 



as originally filed, 
filed with the demand, 
filed with the letter of 
filed with the letter of 



4. Additional observations, if necessary- 



Form PCT IPEA 409(Box 1} (January 1994) 





INTERNATIONAL PRELIMINARY EXAMINATION REPORT 



ternational application No 

PCT/EP00/07622 



111. Non-establishment of opinion with regard to nov 

The questions whether the cla.med invention -PP-"^™ 1 ' <° " 
industrially applicable have not been exam.ned in respect of. 



eltv, inventive step and industrial applicability 



inventive step (to be non obvious), or to be 



| | the entire international application. 
1X1 claims Nos. 



because 



□ 
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Verfahren zur Drehzahlregelung eines Motors, und 
Motor zur Durchfuhrung eines solchen Verfahrens 

Die Erfindung betrifft ein Verfahren zur Drehzahlregelung eines Motors und 
einen Motor zur Durchfuhrung eines solchen Verfahrens. 

Digitale Systeme zur Erfassung und Regelung der Drehzahl eines rotierenden 
Objekts ("Rotor") beruhen darauf, dass ein solcher Rotor pro Umdrehung e.nes 
oder mehrere Signale erzeugt, z.B. Nadelimpulse, Impulsflanken, oder dgl. 
Diese Signale werden nachfolgend auch als "Ereignisse" bezeichnet. Die 
Messung einer Drehzahl beruht darauf, dass der zeitliche Abstand zwischen 
derartigen "Ereignissen" gemessen wird, oder dass gezahlt wird, wiev.ele 
solche "Ereignisse" pro Zeiteinheit auftreten. Bei einem Regelvorgang wird 
diese Drehzahlinformation dazu benutzt, urn die Drehzahl eines Motors auf 
einem vorgegebenen Wert zu halten. Unter Motor (prime mover) wird hier jede 
Art von Motor verstanden, z.B. eine Brennkraftmaschine, ein Elektromotor, em 
pneumatisch oder hydraulisch arbeitender Motor, eine Turbine, etc. Die 
Erfindung findet bevorzugte Anwendung bei der Drehzahlregelung von 
Elektromotoren. 

Da mit zunehmender Drehzahl die Zahl solcher "Ereignisse" pro Zeiteinheit 
zunimmt, wird zu ihrer Verarbeitung in einem digitalen System umso mehr 
Rechenzeit benotigt, je hoher die Drehzahl ist, so dass die Rechenzeit 
abnimmt, die fur andere Prozesse zur Verfiigung steht. 

Es ist eine Aufgabe der Erfindung. ein neues Verfahren zum Regeln der 
Drehzahl eines Motors, und einen Motor zur Durchfuhrung eines solchen 
Verfahrens, bereitzustellen. 

Nach einem ersten Aspekt der Erfindung wird diese Aufgabe gelost durch ein 
Verfahren gemaB Patentanspruch 1. Dadurch, dass zwei numerische 
Frequenzwerte gebildet werden, ist es moglich, einen oder auch beide dieser 
Frequenzwerte einer mathematischen Transformation zu unterziehen und so 
mittels des digitalen Reglers eine gewiinschte Beziehung zwischen erstem 
und zweitem Frequenzwert herzustellen. Haufig wird man einen der 
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numerischen Frequenzwerte, Oder auch beide, mit einem konstanten Faktor 
multiplizieren, was digital oft durch Kommaverschiebung moglich ist und in 
einfacher Weise ein elektronisches Getriebe ermoglicht, doch sind auch 
andere Beziehungen denkbar, z.B. eine Exponentialfunktion, oder eine 
sonstige mathematische Funktion, entsprechend den Forderungen der 
jeweiligen Antriebsaufgabe. 

Eine besonders vorteilhafte Ausgestaltung der Erfindung ist Gegenstand des 
Anspruchs 5. Dadurch, dass mit einer Messung mehrere "Ereignisse" des 
Frequenzsignals erfasst werden konnen, findet eine Mittelwertbildung bei der 
Messung der Frequenzinformation statt. Wird die Frequenz namlich durch eine 
Mehrzahl kurzer Messungen ermittelt, so muss man oft aus mehreren 
Messwerten durch Rechnung einen gleitenden Mittelwert (moving average) 
bilden. Dagegen erhalt man durch die Erfindung ohne zusatzliche Rechnung 
einen Mittelwert, wodurch z.B. ein Mikroprozessor oder Mikrocontroller, beides 
im folgenden kurz jxC genannt, zusatzlich entlastet wird. Und trotz der 
ungefahren Vorgabe einer Messdauer durch die vorgegebenen Zeitpunkte 
findet bei dem Verfahren die eigentliche Messung genau zwischen zwei 
Ereignissen des Frequenzsignals statt. Dies hat sich als besonders vorteilhaft 
erwiesen, da die Messung genau zwischen zwei vorgegebenen Ereignissen 
eines Frequenzsignals eine besonders hohe Genauigkeit ermoglicht. 

Eine andere vorteilhafte Weiterbildung der Erfindung ist Gegenstand des 
Anspruchs 8. Hierdurch wird erreicht, dass bei der Messung einer Drehzahl- 
information bei einem Rotor mit einer festen Anzahl von "Ereignissen" pro 
Rotorumdrehung immer zwischen solchen "Ereignissen" gemessen wird, 
welche derselben Drehstellung des Rotors zugeordnet sind, d.h. es werden 
voile Umdrehungen gemessen. Dies ist insbesondere bei Rotoren interessant, 
welche mehrere "Marken" zur Erzeugung des Rotorstellungssignals 
aufweisen, welche Marken nicht die gleichen Winkelabstande haben. Durch 
die Weiterbildung gemaB Anspruch 8 wird also immer an derselben Stelle des 
Rotors gemessen, so dass die Exaktheit der Winkelabstande keine Rolle spielt. 
Es ergibt sich hierdurch eine hohe Genauigkeit der Messung. Unter "Marken" 
werden hier auch unsichtbare Marken verstanden, z.B. ein Muster in der 
Magnetisierung eines permanentmagnetische Rotors. 
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Eine andere vorteilhafte Weiterbildung der Erfindung ist Gegenstand des 
Anspruchs 12. Durch ein solches Verfahren wird kontinuierlich eine Frequenz- 
information gemessen, denn die folgende Messung schlieBt sich nahtlos an 
die momentane Messung an. In der Nahe von jedem vorgegebenen Zeitpunkt 
wird eine momentane Messung beendet und eine neue Messung begonnen. 
Wenn die vorgegebenen Zeitpunkte jeweils nach einer Zeit T_A auftreten, so 
findet im Mittel jeweils nach der Zeit T_A eine Messung start. Die Verarbeitung 
der Messungen, z.B. in einem uC, findet somit in regelmaBigen Abstanden 
start, welche unabhangig von der Drehzahl sind. Hierdurch wird der uC fur 
diese Aufgaben bei alien Drehzahlen gleichmaBig beansprucht. Da in diesem 
Fall keine Pause zwischen den einzelnen Messungen liegt, ist dieses 
Verfahren besonders gut geeignet, wenn fur die Messung bzw. Regelung jede 
einzelne Umdrehung des Rotors berucksichtigt werden muss, wie es z.B. bei 
Motoren mit hochgenauen Reglern, Oder bei Schrittmotoren, notwendig ist. 

Die Erfindung betrifft ferner ein Verfahren gemaB Anspruch 16. Durch die 
Beriicksichtigung des Rests in der nachfolgenden Messung wird bei einer 
Berechnung der Frequenzinformation mittels Division bewirkt, dass durch 
Rundung keine Frequenzinformation verlorengeht. Dies fiihrt in sehr 
vorteilhafter Weise zu einer Erhohung der Genauigkeit der Messung und ist 
von groBem Vorteil bei komplizierten Regelvorgangen, die hohe Prazision 
erfordern. Zwei oder mehr Motoren konnen dadurch, dass man alien diesen 
Motoren dasselbe Frequenzsignal zufuhrt, also ohne ubergeordneten Regler, 
synchron miteinander laufen. Systeme mit ubergeordneten Reglern sind relativ 
langsam, haben lange Einschwingvorgange, und sie neigen zu Oszillationen, 
besonders bei niedrigen Drehzahlen. Dagegen arbeitet ein Verfahren nach 
der Erfindung schnell, denn die Berucksichtigung des Rests erfordert nur 
wenige Programmschritte. Auch kann ein erfindungsgemaBes Verfahren leicht 
auf andere Parameter umgestellt werden, z.B. auf einen anderen 
"Getriebefaktor", auf andere Regelparameter, etc. 

Die bevorzugte Verwendung eines Ringzahlers gemaB Anspruch 25, und die 
Weiterbildung gemaB Anspruch 26, haben den Vorteil, dass der Stopp der 
einen Messung und der Start der nachfolgenden Messung gleichzeitig sind, 
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weil der Ringzahler standig lauft, so dass keine Fehler durch eine 
Messverzogerung auftreten konnen und sich etwaige Verzogerungen, z.B. 
durch das gleichzeitige Auftreten von zwei Interrupts, nachfolgend sofort 
ausgleichen, weil die Zeit des nachfolgenden Messzyklus automatisch etwas 
zu kurz wird. 

Dies ermoglicht eine luckenlose Erfassung der Drehzahl, und einen mittleren 
Fehler der Drehzahlerfassung, der bei Null liegt, da bei der Messung kein Bit 
verlorengeht. Ein solcher Ringzahler hat gewohnlich einen sogenannten Pre- 
Scaler, mit dem die Frequenz eingestellt werden kann, mit der dieser Zahler 
zahlt. Durch bitweises Einstellen dieser Funktion kann der Ringzahler mit 
verschiedenen festen Vielfachen der Quarzfrequenz des jxC getaktet werden. 
Dadurch konnen Zahlfrequenz und Auflosung des Ringzahlers fur den Anwen- 
dungsfall optimiert werden. Diese Einstellung kann iiber einen Parameter 
erfolgen, der im Motor in einem nichtfluchtigen Speicher gespeichert ist. Auf 
diese Weise kann die Auflosung des Ringzahlers fur unterschiedliche 
Drehzahlbereiche durch unterschiedliche Parameter optimiert sein. 

Weitere Einzelheiten und vorteilhafte Weiterbildungen der Erfindung ergeben 
sich aus den im folgenden beschriebenen und in den Zeichnungen 
dargestellten, in keiner Weise als Einschrankung der Erfindung zu 
verstehenden Ausfuhrungsbeispielen, sowie aus den ubrigen 
Unteranspruchen. Es zeigt: 

Fig. 1 eine Prinzipdarstellung einer erfindungsgemaBen Anordnung zur 
Regelung der Drehzahl eines Motors auf einen Wert, der durch ein 
Frequenzsignal f_s von auBen vorgegeben wird, 

Fig. 2 die Pinbelegung eines beim Ausfuhrungsbeispiel verwendeten |aC, 
hier des Typs PIC 16C72 von Microchip, 

Fig. 3 ein Prinzipschaltbild einer bevorzugten Ausfuhrungsform eines 
Motors nach der Erfindung, hier mit einem Elektromotor 32, 

Fig. 4 ein Frequenzsignal f vor und nach der Signalbearbeitung, 
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Fig. 5 eine schematische Darstellung zur Erlauterung einer Einzelheit der 
Fig. 3, 

Fig. 6 eine schematische Darstellung zur Erlauterung einer Einzelheit der 
Fig. 3, 

Fig. 7 ein schematisierte Darstellung einer Regelanordnung, welche ein 
"elektronisches Getriebe" ermoglicht, 

Fig. 8 ein Flussdiagramm mit einer Ubersicht uber das Gesamtprogramm, 
hier in Form eines sogenannten Funktionsmanagers, 

Fig. 9 ein Funktionsregister, welches im Zusammenhang mit Fig. 8 
verwendet wird, 

Fig. 10 ein Zustandsdiagramm fur ein bevorzugtes Messverfahren zur 
Messung eines Frequenzsignals, 

Fig. 1 1 ein Diagramm, welches beispielhaft die quasi gleichzeitige Messung 
einer Sollfrequenz f_s und einer Istfrequenz f zeigt, 

Fig. 12 ein Flussdiagramm fur eine Funktion TIMERO-lnterrupt, 

Fig. 13 ein Flussdiagramm fur eine Funktion Hall-Interrupt, 

Fig. 14 ein Flussdiagramm fur eine Funktion f_s-lnterrupt, 

Fig. 1 5 ein Flussdiagramm fur eine Funktion CALC_n zur Berechnung des 
aktuellen Werts der Drehzahl (Ist-Drehzahl), 

Fig. 16 ein Flussdiagramm fur eine Funktion CALC_n_s zur Berechnung 
einer Soll-Drehzahl n_s, 

Fig. 17 ein Flussdiagramm fur eine Funktion RGL_ON, welche bestimmt, 
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wann die Funktion RGL der Fig. 18 gestartet wird, 

Fig. 18 ein Flussdiagramm fur die Funktion RGL zur Regelung der Drehzahl; 
diese Funktion ermoglicht ein "elektronisches Getriebe", 

Fig. 19 ein Zustandsdiagramm fur den prinzipiellen Ablauf des 
Regelvorgangs, 

Fig. 20 ein Zustandsdiagramm fur einen Regler, bei welchem auch die Soll- 
Drehzahl n_s = 0 eingestellt werden kann, 

Fig. 21 ein Flussdiagramm fur eine Funktion RGL_ON2, welche an das 
Zustandsdiagramm der Fig. 20 angepasst ist, 

Fig. 22 eine Prinzipdarstellung zur Erlauterung eines bevorzugten 

Messverfahrens bei einem Rotor mit einer einzigen Marke 290, 

Fig. 23 eine schematische Darstellung einer Drehzahlberechnungsfunktion, 

Fig. 24 eine Prinzipdarstellung einer bevorzugten Art der Messung bei einem 
Rotor mit zwei Marken 291 und 292, 

Fig. 25 eine Prinzipdarstellung einer Messung analog Fig. 24, bei welcher 
ein Storsignal S auftritt, zur Erlauterung des hierbei auftretenden 
Vorgange, 

Fig. 26 eine Darstellung mit drei Elektromotoren 181, 183, 185, welche 

unterschiedliche Rotorpolzahlen haben und welche hier durch das 
gleich Sollfrequenzsignal f_s auf dieselbe Drehzahl n geregelt 
werden, 

Fig. 27 eine stark schematisierte Darstellung eines Kopiergerats, das drei 
Antriebsmotoren M1, M2 und M3 hat, welche alle dasselbe 
Steuersignal f_s fur ihre Drehzahl erhalten und welche vermoge der 
Getriebefunktion mit unterschiedlichen Drehzahlen laufen, die in 
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vorgegebenen numerischen Verhaltnissen zu f_s stehen, 

Fig. 28 eine schematisierte Darstellung mit drei Motoren M1 , M2, M3, von 

denen M1 der Master-Motor ist, welcher den beiden anderen Motoren 
M2 und M3 ein Signal TACHO liefert, das ein Ma(3 fur die Drehzahl 
von M1 darstellt und die Drehzahlen der beiden anderen Motoren so 
regelt, dass diese Drehzahlen stets in einem vorgegebenen 
Verhaltnis zur Drehzahl des Motors M1 stehen, und 



Fig. 29 eine schematische Darstellung analog Fig. 6, welche die 

Kommutierung eines elektronisch kommutierten Motors 32" durch den 

|xC 23 zeigt. 

Gleiche oder gleich wirkende Teile werden nachfolgend mit denselben 
Bezugszeichen bezeichnet und gewohnlich nur einmal beschrieben. 

Fig. 1 zeigt ein Blockschaltbild einer erfindungsgemaBen Anordnung 1 8 mit 
einem Motor M. Dieser ist hier als Elektromotor 32 dargestellt, konnte aber ein 
beliebiger anderer Motor sein, dessen Drehzahl mittels eines Stellsignals 
verandert werden kann, z.B. bei einer Brennkraftmaschine mittels einer 
Anderung der Kraftstoffzufuhr, bei einer Dampfturbine uber die Anderung der 
Dampfzufuhr, etc. 

Der Elektromotor 32 ist mit einem Anschluss 33 mit einer positiven 
Betriebsspannung + U_B und mit einem anderen Anschluss 34 mit Masse GND 
verbunden. Mittels eines Stellwerts SW 27 wird die Bestromung des Motors 32 
gesteuert, urn dessen Drehzahl zu regeln. Ein Rotorstellungssignal des Motors 
32 wird als Frequenz f 29 einem Mikroprozessor oder Mikrocontroller, im 
folgenden uC 23 genannt, zugefuhrt. Eine Sollfrequenz f_s 25 wird ebenfalls 
dem uC 23 zugefuhrt, z.B. von einem Frequenzgeber 20, der beispielsweise 
auch ein anderer Elektromotor sein kann, wie nachfolgend bei Fig. 28 
beschrieben. Bei Fig. 28 gibt der Motor M1 uber sein Ausgangssignal die 
Drehzahl der Motoren M2 und M3 vor, d.h. diese konnen z.B. mit derselben 
Drehzahl laufen wie der Motor M1, oder mit anderen Drehzahlen, die zur 
Drehzahl des Motors M1 in einem gewiinschten Drehzahlverhaltnis stehen. 



WO 01/22095 



PCT/EPOO/07622 



-8- 

Da der |iC 23 klein ist, kann er zusammen mit dem Motor 32 zu der Baueinheit 
18 zusammengefasst werden, namlich zu einer Motoreinheit 18 mit 
"elektronischem Getriebe". Dies ist auch bei Elektromotoren moglich, die man 
nach der gangigen Definition als Kleinmotoren oder Kleinstmotoren bezeichnet. 

In dem |j,C 23 ist ein Drehzahlregler n-CTRL 35 realisiert, welcher den Stellwert 
SW 27 so regelt, dass ein testes Verhaltnis zwischen der Sollfrequenz f_s und 
der Istfrequenz f entsteht, welches folgendermaften beschrieben werden kann 
f_s/f = y/z (1) 
wobei y und z ganze Zahlen sind. Dies ist also das vorstehend erwahnte 
"elektronische Getriebe". 

Hierdurch wird es z.B. moglich, einen Motor 181 mit zweipoligem Rotor R_2, 
einen Motor 183 mit vierpoligem Rotor R_4 und einen Motor 185 mit 
sechspoligem Rotor R_6 mit einer einzigen Sollfrequenz f_s synchron zu 
steuern, wie das in Fig. 26 dargestellt ist, so dass z.B. alle drei Motoren mit 
derselben gewunschten Drehzahl n rotieren, die in einem bestimmten Verhaltnis 
zu f_s steht. 

Hierzu wird z.B. f_s / f_2 = 20/2, 
f_s / f_4 = 20 / 4 und 
f_s / f_6 = 20 / 6 

eingestellt, wobei f_2 die Istfrequenz des zweipoligen Rotors R_2, f_4 die 
Istfrequenz des vierpoligen Rotors R_4 und M3 die Istfrequenz des Rotors R_6 
ist. Die Darstellung nach Fig. 26 geht davon aus, dass dort in der ublichen Weise 
zur Erfassung der Rotorstellung ein Hallgenerator verwendet wird, der vom 
Magnetfeld des betreffenden Rotors gesteuert wird, vgl. Fig. 11C und Fig. 29. Die 
Verhaltnisse ergeben sich dadurch, dass bei dem zweipoligen Rotor R_2 zwei 
Wechsel des Hallsignals ("Hallwechsel") pro Umdrehung stattfinden, wahrend 
bei dem vierpoligen Rotor R_4 vier Hallwechsel pro Umdrehung und bei dem 
sechspoligen Rotor R_6 sechs Hallwechsel pro Umdrehung stattfinden. 

Eine solche Anordnung ist vor allem fur Gerate mit mehreren Motoren 
interessant, bei welchen die Motoren ein festes Drehzahlverhaltnis zueinander 
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haben mussen. 



Fig. 2 zeigt die Anschlusse eines uC 23. Bei diesem Ausfuhrungsbeispiel wird 
ein Mikrocontroller der Firma Microchip vom Typ PIC 16C72 verwendet. Dies ist 
ein 8 Bit-Prozessor. Er enthalt einen 16 Bit-Timer und einen 8 Bit-Timer, zwei 
PWM-Register, und mehrere Interruptfunktionen. NaturgemaB stellt dieser 
Prozessor nur ein Beispiel dar, hat sich aber fur die beschriebene 
Ausfiihrungsform als die bevorzugte Losung (best mode) erwiesen. 

Der uC 23 hat u.a. die Anschlusse MCLR 37, VSS 38, CLKIN 39, CLKOUT 40, 
C1 41 , B5 42, B4 43, VDD 44, VSS 45, SDA 46 und SCL 47. 

Fig. 3 zeigt ein stark schematisiertes Schaltbild einer bevorzugte Anordnung 
mit einem Elektromotor 32. 

Die Anschlusse des uC 23 sind in Fig. 2 dargestellt, und die entsprechenden 
Bezugszeichen werden weiter verwendet. Der Anschluss MCLR/ 37 ist uber 
einen Widerstand 71 an einer Plus-Spannung + 5 V angeschlossen. Die 
Anschlusse CLKIN 39 und CLKOUT 40 sind mit einem Oszillatorquarz 75 
verbunden. Der Anschluss VDD 44 ist an + 5 V angeschlossen, der Anschluss 
VSS 45 an Masse GND, und die beiden Anschlusse sind uber einen 
Kondensator 77 miteinander verbunden. Der uC 23 weist zwei Timer TIMERO 
und TIMER1 auf, die in Fig. 1 schematisch dargestellt sind. 

Die Sollfrequenz f_s gelangt uber eine Leitung 25 zu einem Filter FILT_s 51, 
und von dort uber eine Leitung 53 zum Anschluss B4. 

Die durch einen Rotorstellungssensor 61 erfasste Istfrequenz f (entsprechend 
der Drehzahl des Motors 32) gelangt uber eine Leitung 29 zu einem Filter FILT 
57, und von dort uber die Leitung 59 zum Anschluss B5 42 des uC 23. 

Ein EEPROM 80 weist Anschlusse SDA 81, SCL 83, VDD 89, WP 95, VSS 99, 
A1 1 00, A2 1 01 und A3 1 03 auf. 



Der Anschluss SDA 46 des uC 23 ist uber eine Leitung 78 mit dem Anschluss 
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SDA 81 des EEPROM 80 und mit einem externen Anschluss 105 verbunden. 

Der Anschluss SCL 47 des \iC 23 ist iiber eine Leitung 79 mit dem Anschluss 
SCL 83 des EEPROM 80 und mit einem externen Anschluss 107 verbunden. Die 
Anschlusse 105, 107 dienen zur Verbindung mit einem Kommunikationsbus B. 

Die Anschlusse VSS 99, A1 100, A2 101, A3 103 des EEPROM 80 sind mit 
Masse GND verbunden. Der Anschluss WP 95 ist uber einen Widerstand 97 mit 
Masse GND verbunden. Die Anschlusse SDA 81 bzw. SCL 83 sind uber Pullup- 
Widerstande 85 bzw. 87 mit + 5 V verbunden. Der Anschluss VDD 89 ist iiber 
eine Leitung 91 mit + 5 V und iiber einen Kondensator 93 mit Masse GND 
verbunden. 

Der Motor 32 weist ein Stellglied SG 63 auf, welches die GroBe eines durch den 
Motor 32 flieBenden Stromes i beeinflusst. 

Das Stellglied 63 ist uber eine Leitung 33 an die Spannung + U_B 
angeschlossen, und ein Stellwert SW wird dem Stellglied SG 63 uber eine 
Leitung 27 von dem Anschluss C1 des (xC 23 zugefuhrt, um die GroBe des 
Stromes i zu beeinflussen. Zwischen dem Anschluss C1 des \iC 23 und der 
Leitung 27 liegt ein Widerstand 65, und der Punkt 66 ist uber einen Kondensator 
67 mit Masse GND verbunden. Widerstand 65 und Kondensator 67 bilden 
zusammen ein Integrierglied, dessen Funktion nachfolgend anhand von Fig. 5 
erlautert wird. 

Arbeitsweise 

Der |iC 23 erhalt seine Betriebsspannung uber den Anschluss VDD 44 an + 5 V 
und VSS 45 an Masse GND. Uber einen Siebkondensator 77 wird die 
Versorgungsspannung gegen Spannungsspitzen und -einbruche gesichert. Die 
Taktfrequenz des 23 wird mit Hilfe des an die Anschlusse CLKIN 39 und 
CLKOUT 40 angeschlossenen Oszillators 75 erzeugt. 

Die Anschlusse SDA 46 bzw. SCL 47 des |xC 23 dienen zur seriellen 
Ubertragung von Daten zwischen dem |iC 23 und dem EEPROM 80, dort die 
Anschlusse SDA 81 bzw. SCL 83, sowie den externen Anschlussen 105 bzw. 
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107, die z.B. an den externen Bus B geschaltet sind. 

Das EEPROM 80 erhalt seine Spannung uber den Anschluss VDD 89, der uber 
die Leitung 91 mil + 5 V verbunden und zusatzlich uber einen Kondensator 93 
gegen Spannungsspitzen gesichert ist, sowie durch den Anschluss VSS 99, der 
an Masse GND angeschlossen ist. Der Schreibschutz-Anschluss WP 95 ist uber 
den Widerstand 97 auf Masse GND gezogen, so dass in diesem 
Ausfuhrungsbeispiel kein Beschreiben des EEPROM 80 moglich ist. Aus 
demselben Grund sind auch die Anschlusse A1 100, A2 101, A3 103, die zur 
Adresscodierung dienen, auf Masse GND gezogen. In diesem 
Ausfuhrungsbeispiel sind die Parameter im EEPROM 80 festgeschrieben. 
Varianten mit durch den uC 23 oder uber den Bus B beschreibbarem EEPROM 
80 sind in gleicher Weise moglich, vgl. z.B. die PCT-Anmeldung 
PCT/EP99/05186 der Anmelderin vom 21. 07.1999 (PCT216=PCT-3036). 

Die beiden Ausgange SDA 81 bzw. SCL 83 sind als Open-Collector-Ausgange 
ausgebildet, und sie sind deshalb mit den Pull-Up-Widerstanden 85 bzw. 87 
beschaltet. 

Die Sollfrequenz f_s wird von extern, z.B. von einem Frequenzgenerator oder 
einem anderen Motor, geliefert. Die Istfrequenz f wird hier von dem Sensor 61 
geliefert, welcher eine konstante Anzahl von Impulsen pro Umdrehung liefert. 
Als Sensor 61 kann jede bekannte Art von Sensor verwendet werden, z.B. ein 
Resolver, ein Tachogenerator, welcher an seinem Ausgang eine 
Wechselspannung liefert, ein Hallgenerator, oder ein optischer, induktiver oder 
sonstiger Sensor. Da bei elektronisch kommutierten Motoren die Rotorstellung 
gewohnlich mittels eines oder mehrerer Hallgeneratoren erfasst wird, kann das 
Ausgangssignal eines solchen Sensors auch als Istfrequenz verwendet werden, 
da dann Zusatzkosten fur einen Tachogenerator entfallen. Die Verwendung 
eines Tachogenerators kann jedoch dann vorteilhaft sein, wenn man eine hohe 
Frequenz des Signals f fur die Istfrequenz wunscht, z.B. bei niedrigen 
Drehzahlen, z.B. bei einem Schiffsdiesel mit sehr niedriger Drehzahl. 

Die Filter FILT_s 51 bzw. FILT 57 dienen zur Aufbereitung der Flanken der 
Sollfrequenz f_s bzw. der Istfrequenz f, so dass bei einer Flanke an den 
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interruptfahigen Eingangen B5 42 bzw. B4 43 sicher ein Interrupt ausgelost wird. 
Die Filter FILT_s 51 bzw. FILT 57 konnen z.B. als RC-Glied oder als Schmitt- 
Trigger ausgebildet sein. 

Bei geeigneten Signalen f bzw. f_s kann auch eines oder beide der Filter FILT_s 
51 und FILT 57 entfallen. 

Ein Beispiel fur die Wirkung der Filter ist in Fig. 4 gezeigt. 

Fig. 4A zeigt die Istfrequenz f, bevor sie in das Filter FILT 57 gelangt, und Fig. 
4B zeigt die Istfrequenz f, nachdem sie in dem Filter FILT 57 aufbereitet wurde. 

Die Istfrequenz f aus Fig. 4A stammt z.B. von einem Hallgenerator, und die 
Flanken 109 sind weniger steil. 

Die Istfrequenz f aus Fig. 4B ist durch das Filter FILT 57 aufbereitet worden. Die 
Flanken 110 sind steil, und es kann sicher durch die Flanken 110 im |iC 23 ein 
Interrupt ausgelost werden. 

Ein in dem |iC 23 berechneter Stellwert RGL_VAL (Fig. 7) wird uber den 
Anschluss C1 41 als pulsweitenmoduliertes Signal (PWM-Signal) PWM_SW 
ausgegeben. Das Signal PWM_SW wird uber ein aus dem Widerstand 65 und 
dem Kondensator 67 bestehendes RC-Glied zu einer dem jxC-internen Stellwert 
RGL_VAL etwa proportionalen analogen Spannung umgewandelt, welche als 
Stellwert SW bezeichnet wird und dem Stellglied SG 63 uber die Leitung 27 
zugefuhrt wird. Das Stellglied SG 63 steuert die Stromzufuhr ftir den Motor M 32. 
Das Stellglied SG 63 kann z.B. als analoger Langssteller oder als PWM- 
Stellglied ausgefuhrt sein, oder in sonstiger Weise. 

Fig. 5A zeigt das PWM-Signal PWM_SW von Anschluss C1 41 aus Fig. 3, und 
Fig. 5B zeigt in idealisierter Form den Stellwert SW, welcher am Punkt 66 aus 
Fig. 3 durch das aus dem Widerstand 65 und dem Kondensator 67 gebildeten 
RC-Glied entsteht, wenn das Tastverhaltnis von PWM_SW abnimmt. 

Je nach Tastverhaltnis TV_SW des PWM-Signals PWM_SW aus Fig. 5A hat der 
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Stellwert SW aus Fig. 5B eine bestimmte Spannung U zwischen 0 und MAX. 



Das Tastverhaltnis TV ist allgemein definiert als 



TV = t_on/T 



(2) 



also dem Quotienten aus der Zeit t_on (Fig. 5A), die das PWM-Signal auf HIGH 
ist, hier von 121 bis 123, und aus der Periodendauer T des PWM-Signals, hier 
von 121 bis 125. Das Tastverhaltnis wird in Prozent angegeben, so dass es die 
Werte 0 Prozent bis 100 Prozent annehmen kann. 

In Fig. 5A nimmt das Tastverhaltnis von links nach rechts ab, so dass auch das 
Signal SW in Fig. 5B von links nach rechts abnimmt. 

Das Signal SW wird dem Stellglied SG 63 aus Fig. 3 uber die Leitung 27 
zugefuhrt, und so kann durch das Tastverhaltnis TV_SW die Motordrehzahl 
gesteuert werden. 

Fig. 6A zeigt rein beispielhaft ein Ausfuhrungsbeispiel fur das Stellglied SG 63 
aus Fig. 3, welches zur Steuerung der Drehzahl n eines Motors 137 dient, der 
hier als Kollektormotor dargestellt ist. 

Das Stellglied SG 63 weist einen Komparator 131 mit einem Pluseingang 132 
und einem Minuseingang 133, einen Dreiecksgenerator DG 134 und einen npn- 
Transistor 1 35 auf. 

Von Punkt 66 wird dem Pluseingang 132 des Komparators 131 das Signal SW 
zugefuhrt. Das von dem Dreiecksgenerator DG 134 erzeugte Dreieckssignal 
u_D wird dem Minuseingang 133 des Komparators 131 zugefuhrt. Am Ausgang 
des Komparators 131 entsteht ein PWM-Signal PWM_M, welches dem 
Transistor 135 zugefuhrt wird. Der Transistor 135 schaltet zwischen der uber die 
Leitung 33 angeschlossenen Betriebsspannung + U_B und dem uber die 
Leitung 35 verbundenen Motor M 137, dem ein Tachogenerator 138 zur 
Erzeugung einer drehzahlproportionalen Frequenz f zugeordnet ist. 

Fig. 6B zeigt einen Beispielverlauf fur die Spannungen u_D und SW, und Fig. 
6C zeigt ein sich daraus ergebendes Signal PWM_M, mit dem der Transistor 



WO 01/22095 



PCT/EP00/07622 



- 14- 

135 ein- und ausgeschaltet wird. 

Der Komparator 131 vergleicht die beiden Signale u_D und SW. 1st der Stellwert 
SW groBer als die Dreiecksspannung u_D, so ist das PWM-Signal PWM_M auf 
HIGH, ansonsten ist es auf LOW. Durch die Hohe des Stellwerts SW wird also 
das Tastverhaltnis des PWM-Signals PWM _M gesteuert. In Fig. 6B nimmt das 
Signal SW von links nach rechts zu. Dadurch wird auch das Tastverhaltnis des 
Signals PWM_M in Fig. 6C von links nach rechts erhoht. 

Da der Motor 137 bei einem hoheren Tastverhaltnis des Signals PWM_M liber 
den Transistor 135 auch mehr Strom und damit Leistung erhalt, kann uber die 
Hohe des Stellwerts SW die Motordrehzahl gesteuert werden. 

Fig. 29 zeigt eine Variante zu Fig. 6. Gleiche oder gleich wirkende Teile 
erhalten deshalb dieselben Bezugszeichen wie in Fig. 6. - Der Motor ist hier als 
sogenannter zweistrangiger, zweipulsiger elektronisch kommutierter Motor 
(ECM) 32" dargestellt, der als Beispiel einen zweipoligen permanentmag- 
netischen Rotor 732 hat. Dieser steuert durch sein Magnetfeld einen 
Hallgenerator 61 , welcher das Signal f erzeugt und mit diesem Signal auch die 
Kommutierung des ECM 32" steuert. Der ECM 32" kann z.B. gemaB der 
DE 23 46 380 C2 gebaut sein. NaturgemaB ist dies nur ein Beispiel. Die 
Erfindung eignet sich in gleicher Weise fur ECMs mit einer anderen Zahl von 
Strangen und einer anderen Zahl von Rotorpolen, wie das fur den Fachmann 
selbstverstandlich ist. 

Die beiden Strange des ECM 32" sind mit 736 und 738 bezeichnet. Der Strom ii 
im Strang 736 wird gesteuert von einem npn-Darlingtontransistor 740 mit 
Freilaufdiode 742, und zur Steuerung des Stromes \2 im Strang 738 dient ein 
npn-Darlingtontransistor 744 mit Freilaufdiode 746. Die Emitter der Transistoren 
740, 744 sind miteinander und uber einen Widerstand 748 mit GND verbunden. 

Der Transistor 740 wird von einem Port OUT1 des jnC 23 uber ein UND-Glied 
750 gesteuert, dessen anderem Eingang das Signal PWM_M vom PWM-Steller 
63 zugefuhrt wird. Fig. 29 zeigt schematisch die Form dieses Ausgangssignals. 
Es handelt sich urn Rechteckimpulse mit z.B. 25 kHz. Die Breite dieser Impulse 
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wird durch die Hohe der Spannung am Eingang 132 des Stellers 63 bestimmt. 
Der Transistor 740 wird nur leitend gesteuert, wenn sowohl am Ausgang des 
Stellers 63 wie am Ausgang OUT1 des uC 23 das logische Signal "1" 
vorhanden ist. 

Ebenso wird der Transistor 744 von einem Port OUT2 des uC 23 uber ein UND- 
Glied 752 gesteuert, dessen anderem Eingang das Signal PWM_M vom Steller 
63 zugefiihrt wird. Der Transistor 744 wird also nur leitend gesteuert, wenn 
sowohl am Ausgang des PWM-Stellers 63 wie am Ausgang OUT2 des 23 
das logische Signal "1" vorhanden ist. 

Zwischen dem Ausgang des UND-Glieds 750 und der Basis des Transistors 740 
liegt ein Widerstand 754, und analog beim Transistor 744 ein Widerstand 756. 

Wie nachfolgend bei Fig. 13, S310 und S314 beschrieben wird, werden die 
Ausgange OUT1 und OUT2 des uC 23 alternierend auf High und Low geschaltet 
und steuern dadurch, welcher der beiden Strange 736, 738 Strom erhalten soil. 
Die Hohe der Stroma M, i2 wird vom Signal am Punkt 66 bestimmt, welches das 
Tastverhaltnis des Signals PWM_M bestimmt, wie bei Fig. 6 ausfuhrlich 
beschrieben. 

Schematische Ubersicht uber eine bevorzugte Ausfuhrungsform des 
Programms 

Fig. 7 zeigt eine Ubersicht uber das in dem ^C 23 ablaufende Programm. Das 
Programm weist eine Sollwertmessung "MEAS f_s" 141 und eine Sollwert- 
berechnung "CALC n_s" 143, eine Istwertmessung "MEAS f" 147 und eine 
Istwertberechnung "CALC n" 149 , ein "Getriebe" 145 und den Drehzahlregler n- 
CTRL 35 (Fig. 1) auf. Der digitale Drehzahlregler n-CTRL 35 weist hier einen 
Regeldifferenzberechner 151, einen Pl-Regler "PI-RGL" 153 und eine 
Stellwertausgabe "GEN PWM" 155 auf, an deren Ausgang das Signal PWM_SW 
erzeugt wird. 

Die Sollfrequenz f_s wird in "MEAS f_s" 141 gemessen. Es werden dabei die 
Anzahl der Flanken (110 in Fig. 4) seit der letzten Messung in einer Variablen 
INT_MEAS_f_s und der Zeitpunkt der aktuellen Messung in einer Variablen 
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t_MEAS_f_s gemessen. 

Die Sollwertberechnung "CALC n_s" 143 berechnet hieraus die Solldrehzahl 
n_s. Dies wird nachfolgend anhand von Fig. 15 erlautert. 

Die Messung der Istfrequenz f in "MEAS f" 147 und die Berechnung der 
Istdrehzahl n in "CALC n" 149 geschieht vollig analog zu der Messung der 
Sollfrequenz f_s in "MEAS f_s" 141 und die Solldrehzahl n_s wird in "CALC n_s" 
143 berechnet. 

Die Solldrehzahl n_s wird in "X * n_s" 145 mit einem Faktor X multipliziert, und 
dieses Produkt, sowie die Istdrehzahl n, werden dem Regeldifferenzberechner 
151 zugefuhrt. Mit X = 2 wird z.B. erreicht, dass dem Regeldifferenzberechner 
151 der doppelte Wert der gemessenen Solldrehzahl zugefuhrt wird, wahrend 
z.B. bei X = 1/2 dem Regeldifferenzberechner 151 ein Wert zugefuhrt wird, 
welcher der halben Solldrehzahl entspricht. So wird durch "X * n_s" 145 eine 
Getriebefunktion erreicht, wobei sehr vorteilhaft ist, dass hierbei auch Faktoren 
eingestellt werden konnen wie z.B. X = 1,733. 

Fig. 7 zeigt auch - gestrichelt - eine Variante mit dem Block 145', in dem die Ist- 
Drehzahl n mit einem Faktor Y multipliziert wird. Im Normalfall wird man die 
Variante 145 bevorzugen, also X * n_s, weil dann alle Motoren eines Systems 
gleich aufgebaut sein konnen und man den Getriebefaktor X uberall nach 
denselben Regeln einstellen kann. 

Eine in dem Regeldifferenzberechner 151 berechnete Regeldifferenz RGLJDIFF 
wird der Reglerfunktion "PI-RGL" 153 zugefuhrt, welcher hieraus den Reglerwert 
RGL_VAL berechnet. Wie dies geschieht, wird nachfolgend anhand von Fig. 18 
ausfuhrlich beschrieben. 

Der Wert RGL_VAL wird der Stellwertausgabe "GEN PWM" 155 zugefuhrt, 
welche ihn bei diesem Beispiel in ein PWM-Signal PWM_SW umwandelt, 
welches am Ausgang C1 des iiC 23 in Fig. 3 ausgegeben wird, und welches in 
Fig. 5 naher beschrieben ist. Mit Hilfe des Signals PWM_SW wird die Drehzahl 
des Motors M so gesteuert, dass die Regeldifferenz RGL_DIFF zu Null wird. 
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Allgemeiner Aufbau des Gesamtprogramms; Funktionsmanager 

lm folgenden wird an einem bevorzugten Ausfiihrungsbeispiel die Architektur 
des in dem jiC 23 ablaufenden Gesamtprogramms beschrieben. AnschlieBend 
werden die Unterprogramme im einzelnen beschrieben. Diese sind speziell fur 
einen preiswerten Mikrocontroller ausgelegt. Wird ein teurer Prozessor 
verwendet, so sind im Rahmen der Erfindung auch andere Uosungen moglich, 
doch hat die beschriebene Version den Vorzug, dass sie sehr kostengunstig 
realisiert werden kann, so dass sich gegenuber einem mechanischen Getriebe 
hohe Einsparungen ergeben konnen. 

Fig. 8 zeigt ein Flussdiagramm mit einer bevorzugten Ausfuhrungsform des in 
dem uC 23 ablaufenden Gesamtprogramms. 

Ganz oben stehen drei Interruptroutinen Hall-Interrupt S631 (Fig. 13). f_s- 
Interrupt S635 (Fig. 14) und TIMERO-lnterrupt S639 (Fig. 12), welche beim 
Auftreten des jeweiligen Interrupts 630, 634 bzw 638 ausgefuhrt werden, und 
welche uber 632, 636, 640 auf das Hauptprogramm einwirken. Dabei nimmt die 
Prioritat, also die Reihenfolge, in der die einzelnen Programmteile ausgefuhrt 
werden, von oben nach unten ab. Die Prioritaten sind deshalb auf der rechten 
Seite mit L1 bis L10 bezeichnet, wobei L1 die hochste Prioritat hat. 

Unter den Interruptroutinen ist das Hauptprogramm dargestellt. Nach dem 
Einschalten des Motors 32 wird in dem uC 23 ein interner Reset ausgeldst. In 
S600 erfolgt die Initialisierung des uO 23. Es werden z.B. Parameter aus dem 
EEPROM 80 ausgelesen und in das RAM des uC 23 ubertragen. 

Nach der Initialisierung erfolgt ein Sprung in einen sogenannten 
Funktionsmanager 601, der in S602 beginnt. Der Funktionsmanager 601 regelt 
den Ablaut der einzelnen Unterprogramme. 

Als erstes werden die Funktionen abgearbeitet, die zeitkritisch sind und bei 
jedem Durchlauf ausgefuhrt werden mussen. Hierzu zahlt z.B. eine 
Kommunikationsfunktion COMM in S604, welche die Dateniibertragung 
zwischen dem uC 23, dem EEPROM 80 und dem externen Busanschluss B 
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durchfuhrt. S606 steht fur evtl. vorhandene weitere zeitkritische Funktionen. 

Fig. 9 zeigt ein beispielhaftes Funktionsregister 605, in dern fur jede weitere 
Funktion aus Fig. 8 ein Bit reserviert ist. 

In diesem Ausfuhrungsbeispiel ist das Funktionregister 605 1 Byte groB, und es 
sind, von dem niederwertigsten Bit (LSB) beginnend, die folgenden 
Anforderungsbits fur die nachfolgend erklarten anforderbaren Funktionen 
definiert: 

- FCT_XY fur eine beliebige Funktion S612 

- FCT_CALC_n fur eine Istwertberechnungsfunktion CALC_n S616 (Fig. 15) 

- FCT_CALC_n_s fur eine Sollwertberechnungsfunktion CALC_n_s S620 

(Fig. 16) 

- FCT_RGL_ON fur eine Reglerstart-Uberpriifungsfunktion RGL_ON S624 

(Fig. 17) 

- FCT_RGL fur eine Reglerfunktion RGL S628 (Fig. 18). 

Die restlichen Bits Bit5 bis Bit7 sind fur weitere anforderbare Funktionen 
reserviert, die gegebenenfalls in den Funktionsmanager 601 integriert werden 
konnen. 

Die Istwertberechnungsfunktion CALC_n S616 (Fig. 15) dient zur Berechnung 
der Istdrehzahl n, die Sollwertberechnungsfunktion CALC_n__s S620 (Fig. 16) 
dient zur Berechnung der Solldrehzahl n_s, die Reglerstart- 
Uberprufungsfunktion RGL_ON S624 (Fig. 17) uberpruft, ob die Bedingungen fur 
den Start der folgenden Funktion RGL S628 (Fig. 18) vorliegen, und fordert 
diese gegebenenfalls an. Die Reglerfunktion RGL S628 schlieBlich berechnet 
den neuen Stellwert RGL_VAL (Fig. 7) und gibt diesen an das Stellglied SG 63 
des Motors 32 aus. 

Soli eine bestimmte anforderbare Funktion durch eine andere Funktion oder 
eine Interruptroutine angefordert werden, so wird das Bit der angeforderten 
Funktion in dem Funktionsregister 605 (Fig. 9) auf 1 gesetzt, z.B. FCT_XY = 1. 
Wenn der Funktionsmanager 601 bei einem Durchlauf keine andere 
anforderbare Funktion mit hoherer Prioritat findet, wird anschlieRend diese 
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Funktion ausgefuhrt. 

1st eine angeforderte Funktion abgearbeitet, so setzt sie selbst ihr 
Anforderungsbit wieder auf 0, also z.B. FCT_XY = 0. Dies ermoglicht es, langere 
Funktionen, die nicht in einem Durchlauf abgearbeitet werden konnen, we.l s.e 
z.B. eine zu lange Zeit benotigen wiirden, aufzuteilen und in mehreren Aufrufen 
abzuarbeiten. 

In Fig. 8 wird nach S606 in einer vorbestimmten Reihenfolge, von der 
wichtigsten anforderbaren Funktion ausgehend, jeweils gepriift, ob deren 
Anforderungsbit gesetzt ist. 1st dies bei einer Funktion der Fall, so wird diese 
ausgefuhrt, und daraufhin wird wieder an den Anfang FCT_MAN S602 des 
Funktionsmanagers 601 gesprungen. Die Reihenfolge der Uberprufung des 
Funktionsregisters 605 gibt die Prioritierung der anforderbaren Funkt.onen vor. 
Je hoher eine solche Funktion in dem Funktionsmanager 601 steht, desto hoher 
ist ihre Prioritat. 

Anhand eines Beispiels soil die Funktionsweise des Funktionsmanagers 
FCT.MAN 601 erlautert werden. Springt z.B. das Prograrnm von S610 nach 
S614 so wird in S614 uberpruft, ob das Funktionsregisterbit FCT_CALC_n = 1 
ist, ob also die Istwertberechnung CALCn S616 angefordert wurde, die in Fig. 
15 dargestellt ist. Ist dies der Fall, so wird nach S616 gesprungen, und die 
Drehzahlberechnung wird durchgefuhrt. Bei Beendigung setzt die 
Drehzahlberechnung CALC.n S616 das Anforderungsbit FCT_CALC_n wieder 
auf 0 zuriick, vgl. S374 in Fig. 15, und es wird wieder an den Anfang S602 des 
Funktionsmanagers 601 gesprungen. 

War in keiner der Abfragen bis S626 ein Anforderungsbit gesetzt, so wird ohne 
eine Aktion nach S602 zuruckgesprungen, und die Funktionen S604 und S606, 
die bei jedem Durchlauf des Funktionsmanagers 601 ausgefuhrt werden, 
werden emeut abgearbeitet. 



Durch den Funktionsmanager erhalt man eine optimale Ausnutzung 
Ressourcen des jxC 23. 
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Ist- und Sollwertmessung 

Die Messung der Istfrequenz f und der Sollfrequenz f_s laufen gleich, aber 
unabhangig voneinander, ab. Man kann auch sagen, sie laufen quasiparallel 
ab, wobei quasi dafur steht, dass in diesem Ausfuhrungsbeispiel kein echter 
Parallelprozessor verwendet wird, was im Rahmen der Erfindung ebenfalls 
moglich sein wurde. Im folgenden wird zunachst die Istfrequenzmessung 
betrachtet. Die Istfrequenz ist ein MaB fur die Drehzahl des Motors 32 (Fig. 3). 

Prinzip der Messung 

Fig. 22 zeigt einen Rotor 32 mit einer Marke 290, und einen Sensor 61 fur die 
Marke 290, der als Rotorstellungssensor dient. Der Rotor 32 ist gewohnlich Teil 
eines Motors M. Sofern es sich um einen elektronisch kommutierten Motor 
(ECM) handelt, hat dieser gewohnlich einen Rotorstellungssensor 61, der dann 
auch fur die vorliegende Erfindung verwendet werden kann. 

Der Rotorstellungssensor 61 detektiert mit Hilfe der Marke 290 ein 
Rotorstellungssignal f. Das Rotorstellungssignal f weist Impulse an den Stellen 
165, 166, 167 und 168 etc. auf, wobei zwischen jeweils zwei Impulsen eine 
Umdrehung des Rotors 32 stattgefunden hat. Die Zeitachse ist mit t bezeichnet. 
Diese Impulse stellen "Ereignisse" (events) bei der Drehung des Rotors 32 dar. 
Bei Fig. 22 wird pro Rotorumdrehung 1 Ereignis erzeugt, namlich 1 Impuls. 

Mit Hilfe des Rotorstellungssignals f wird wie folgt die Drehzahl des Rotors 32 
gemessen. In regelma3igen Abstanden T_A wird ein Startsignal 261, 263 etc. 
erzeugt, mit dem jeweils eine neue Messung angefordert wird. 

Auf das Startsignal an der Stelle 261 folgt der Impuls 265, und auf das 
Startsignal an der Stelle 263 der Impuls 268. Die Messung geschieht zwischen 
den Stellen 265 und 268. Gemessen werden die Anzahl N der Impulse des 
Rotorstellungssignals f, welche nach 265 bis einschlieBIich 268 auftreten, also 
hier N = 3, und die fur diese Impulse benotigte Zeit At(1 65-268). Hieraus lasst 
sich die Frequenz des Rotorstellungssignals f und damit die Drehzahl des Rotors 
32 bestimmen. An den Stellen 265, 268 der Messung wird jeweils eine alte 
Messung beendet und eine neue Messung gestartet. Man geht also so vor, dass 
bei dem auf das Startsignal 261 , 263 folgenden Impuls jeweils eine alte 
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Messung beendet und simultan eine neue Messung begonnen wird. 

Die Anzahl N der Impulse kann z.B. in einem Zahler gemessen werden, indem in 
diesem Zahler der Wert N am Ende jeder Messung auf Null zuruckgesetzt wird 
und anschlieBend der Zahlerwert N bei jedem Impuls urn 1 erhoht wird. 

Die Zeit At kann z.B. gemessen werden, indem die Differenz zwischen der Zeit 
des Starts der Messung, z.B. t(265) an der Stelle 265, und der Zeit des Endes 
der Messung, z.B. t(268) an der Stelle 268. gebildet wird. 

Betragt z.B. t(265) = 17,7 ms und 
t(268) = 87,7 ms, 
so ist 

At(265-268) = 87,7 ms - 17,7 ms = 70 ms. 

Durch die Startsignale 261 , 263, welche in festen Abstanden T_A auftreten, wird 
ein Messfenster verwirklicht. Die Messungen finden jedoch nicht genau zu dem 
Zeitpunkt des jeweiligen Startsignals statt, sondern gemessen wird an einer 
geeigneten, auf das jeweilige Startsignal folgenden Stelle, an der ein Impuls 
("Ereignis") des Rotorstellungssignals f auftritt. Bei einer Messung zum Zeitpunkt 
des jeweiligen Startsignals wiirden der Anfang und das Ende der Messung in 
der iiberwiegenden Anzahl der Falle an einer Stelle zwischen zwei Impulsen 
des Rotorstellungssignals stattfinden. Dies wiirde zu einer Ungenauigkeit der 
Messung fiihren. Wartet man jedoch bis zum nachsten Impuls, so werden voile 
Perioden zwischen den Impulsen gemessen, was zu einer starken Erhohung der 
Genauigkeit der Messung fiihrt. 

Fig. 23 zeigt schematisch eine Berechnung der Drehzahl n in einer 
Drehzahlberechnungsfunktion 270. Die Funktion 270 bekommt in zeitlichen 
Abstanden, welche im Mittel die Dauer T_A haben, als Eingabe die Anzahl N der 
Impulse und die fur diese Anzahl N benotigte Zeit At. Hieraus berechnet die 
Funktion 270 eine Drehzahlinformation n als Quotient aus der Anzahl N und der 
Zeit At 

n = N/At (3) 
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Die Einbeziehung der Modulo-Funktion in die Messung 
Fig. 24 zeigt den Rotor 32' (eines Motors M_2) mit zwei Marken 291 und 292 
und dem Rotorstellungssensor 61. Die Marken 291 und 292 sind ungefahr 
180° mech. versetzt. 

Der Rotorstellungssensor 61 erfasst mit Hilfe der Marken 291 und 292 ein 
Rotorstellungssignal f. Das Rotorstellungssignal f hat aufgrund der Marke 291 
Impulse (weiB gefullt dargestellt) an den Stellen 276, 278, 280 und 282 und 
aufgrund der Marke 292 Impulse (schwarz gefullt dargestellt) an den Stellen 
275, 277, 279 und 281. Zwischen jeweils zwei "weiBen" Impulsen bzw. zwischen 
jeweils zwei "schwarzen" Impulsen hat sich der Rotor 32' einmal gedreht. 

Da die Impulse, welche durch die Marken 291 und 292 generiert werden, nicht 
unterschieden werden konnen, kann allgemeiner gesagt werden, dass zwischen 
jedem impuls und dem ubernachsten Impuls, z.B. zwischen N = 1 und N = 3, 
eine voile Umdrehung des Rotors 32' stattfindet. 

Der Messung der Drehzahl n des Rotors 32' liegen bei Fig. 24 folgende 
Uberlegungen zugrunde: 

Die Marken 291, 292 konnen niemals vollkommen symmetrisch angeordnet 
werden. Nimmt man an, dass die Marke 291 bei 0° mech. liegt, so musste die 
Marke 292 exakt bei 180° mech. liegen. Infolge von mechanischen Fehlern kann 
sie aber z.B. bei 183° mech. positioniert sein. Hierdurch kame es bei einer 
Messung, welche an der Stelle 276 (Marke 291) startet und bei der Stelle 
281 (Marke 292) endet, zu einem Messfehler, da dann der gemessene 
Winkelbereich nicht genau ein Vielfaches von 180° mech. ist. 

Um diesem Problem zu begegnen, werden in Fig. 24 jeweils nur voile 
Umdrehungen gemessen, d.h. es wird immer zwischen der gleichen Art von 
Marke gemessen, und damit wird immer genau ein Vielfaches von 360° mech. 
gemessen. Die Messung, die bei 276 beginnt, namlich nach dem Startimpuls 
271, endet daher nicht an der Stelle 281, sondern an der Stelle 282, welche die 
nachste auf das Startsignal 273 folgende Stelle ist, an der, von dem Start der 
Messung an der Stelle 276 aus betrachtet, wieder eine voile Umdrehung 
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stattgefunden hat. 

Diese Bedingung kann mathematisch mit der Funktion MODULO (mod) 
beschrieben werden, wobei z.B. 

(4) 

N mod 2 = 0 v ' 

bedeutet, dass bei einer Division des Wertes N durch 2 der Rest 0 iibngbleibt. 
So ist z.B. 0 mod 2 = 0, 1 mod 2 = 1 , 2 mod 2 = 0. 3 mod 2 = 1 usw.. Ebenso ist 
0 mod 4 = 0, 1 mod 4 = 1, 2 mod 4 = 2, 3 mod 4 = 3 und 4 mod 4 = 0, etc. 

In Fig. 24 ist bei 283 N mod 2 unter den Impulsen 275 bis 282 eingetragen, und 
eine Messung endet/startet z.B. nur, wenn durch ein Startsignal 271 , 273 eine 
Messung angefordert ist UND zusatzlich die Bedingung N mod 2 = 0 erfullt ist. 
Allgemeiner gesagt, sollte bei Fig. 24 der Wert von N mod 2 bei Start und Stopp 
der Messung derselbe sein. 

Hat ein Rotor eine Zahl von A Marken, so lautet die Bedingung der Gleichung (4) 

allgemein 
N mod A = 0 
bzw. 

(5) 

N mod A = const. v ' 

lm folgenden wird die Grosse A mit MODJ bezeichnet, also A = MOD_f, und 

Gleichung (5) lautet dann 
N mod MODJ = 0 
bzw. 

N mod MODJ = const ( 5a ' 

Die Wahl der ersten Marke kann dabei entweder durch ein besonderes Signal 
erfolgen, oder es kann das erste gemessene Signal als Impuls mit N = 0 gewahlt 
werden. Aus der Erlauterung zu Fig. 13 wird dies noch deutlicher werden. 

Die Messung erfolgt also bei Fig. 24 entweder, wie dargestellt, zwischen 
"weiBen" Impulsen, oder, wie in Fig. 15 rechts dargestellt, zwischen "schwarzen" 
Impulsen. Beim Beispiel der Fig. 24 erfolgt die Messung zwischen den Impulsen 
276 und 282. Dort werden N = 6 Impulse gezahlt, und der zeitliche Abstand 
zwischen den Impulsen 276 und 282 wird ermittelt und betragt At(276-282). Aus 
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diesen beiden Werten wird dann gemass Gleichung (3) eine 
Drehzahlinformation n errechnet. 

Es wird hervorgehoben, dass es in der Realitat keine "weiBen" oder "schwarzen" 
Impulse gibt, sondern dass dies ein didaktisches Hilfsmittel zur Erlauterung 
eines Aspekts der Erfindung ist. 

Was geschieht bei Storimpulsen? 

Fig. 25 zeigt einen Rotor 32' mit zwei Marken 781 und 782 und dem 
Rotorstellungssensor 61 analog zu Fig. 24. Das Rotorstellungssignal f weist 
Ereignisse in Form von Impulsen an den Stellen 717, 718, 719, .... 728 auf. Die 
Impulse werden abwechselnd von der weissen Marke 781 und der schwarzen 
Marke 782 erzeugt, wenn diese an dem Rotorstellungssensor 61 vorbeidrehen 
und sind deshalb - zum besseren Verstandnis - weiss und schwarz dargestellt. 
Zusatzlich tritt ein Storimpuls S zwischen den Impulsen 720 und 721 auf. 
Weiterhin sind Steuersignale 711, 713 und 715 zur Anforderung einer Messung 
dargestellt. 

Unter den Impulsen ist in der Reihe 732 der Wert des Zahlers N fur die Anzahl 
der Impulse und in der Reihe 730 das Ergebnis der Berechnung von N mod 2 
angegeben. 

Eine Messung endet/beginnt im Normalfall immer dann, wenn durch ein 
Steuersignal 711, 713 bzw. 715 eine Messung angefordert ist und zudem der 
Wert von N mod 2 gleich Null ist, wenn sich der Rotor 32' also seit der letzten 
Messung ein ganzzahliges Vielfaches einer Umdrehung gedreht hat. 

Der Storimpuls S bewirkt, dass bei der Messung in dem Zeitraum At(71 8-723) 
angenommen wird, dass der Rotor 32' zwischen den Impulsen 720 und 721 eine 
ganze Umdrehung zuruckgelegt hat, obwohl er erst eine halbe Umdrehung 
zuruckgelegt hat. Hierdurch wird nach dem Steuersignal 713 anstatt bei dem 
"weissen" Signal 722 bei dem "schwarzen" Signal 723 gemessen, da N mod 2 
nach dem Storimpuls S nicht mehr bei den "weissen" Impulsen den Wert Null 
hat, sondern bei den "schwarzen" Impulsen. 
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Schon in dem folgenden Zeitraum At(723-727) funktioniert die Messung jedoch 
wieder richtig, da jetzt jeweils bei "schwarzen" Impulsen gemessen w.rd. Es 
findet also durch den Storimpuls S eine Verschiebung derjenigen Stellung des 
Rotors 32" start, an der gemessen wird. Dasselbe wurde gelten, wenn ein Impuls 
fehlen wurde. Das Messverfahren arbeitet also nach einem Fehlersignal S 
richtig weiter und misst weiterhin ein Vielfaches von einer ganzen Umdrehung. 
Dies stellt einen wichtigen Vorteil dieser Ausfuhrungsform dar. 

Fig 10 zeigt ein Zustandsdiagramm fur die Messung der Istfrequenz. Das 
Zustandsdiagramm weist vier Zustande S1 , S2, S3 und S4 sowie sechs 
Ubergange T1 , T2 T6 auf. 

Zu jedem Ubergang gehort ein Ereignis und eine Aktion. 

Die folgende Tabelle 1 zeigt fur jeden Ubergang das zugehorige Ereignis und 
die zugehorige Aktion. 



Ubergang Ereignis Akt,on 

T1 Interrupt durch Flanke des TIMER1 lesen und 

! Signals f \ speichern, INT_CNT_f 

erhohen 

J2 Interrupt durch TIMERO nach Istwert-, Soljwertberechnung 

Zeit T_A 



T3 



T4 



und Regler freigeben 



Interrupt durch Flanke des TIMER1 lesen und 
Signals f i speichern, INT_CNT_f 

i erhohen 

INT CNTJ mod MODJ = 0 t_MEAS_f , INT_MEAS_f 

berechnen, CALC n starten 



T5 



instantan 



keine 



T6 



instantan 



Vorbereitung fur neue 
Messung 
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Fig. 11 zeigt ein zugehoriges Diagramm mit einem Beispielablauf fur die 
Messung der Sollfrequenz f_s und der Istfrequenz f. 

Fig. 11 A zeigt Interrupts 161, 163, 165 eines Timers TIMERO (im 23), 
welche jeweils nach einer Zeit T_A, z.B. T_A = 25 ms, ausgelost werden. 

Fig. 11B zeigt die Sollfrequenz f_s, welche dem |uC 32 z.B. von dem 
Frequenzgenerator 20 (Fig. 1) zugefuhrt wird. An den Stellen 167, 169 und 171 
werden jeweils die beiden Variablen INT_MEAS_f_s fur die Anzahl der Flanken 
seit der letzten Messung und t_MEAS_f_s mit dem mit Hilfe des Timers TIMER1 
bestimmten Zeitpunkt der momentanen Messung an die Sollwertberechnung 
weitergegeben. Die in Klammern angegebenen Zahlen bezeichnen den 
jeweiligen Zeitpunkt bzw. Zeitbereich, fur den der jeweilige Wert gilt. So wird z.B. 
zum Zeitpunkt 169 der Wert INT_MEAS_f_s(167-169), der die Anzahl der 
Flanken in dem Bereich von 167 bis 169 enthalt, und der Wert 
t_MEAS_J_s(169), der den Zeitpunkt der Messung bei 169 enthalt, an die 
Sollwertberechnung CALC_n_s S620 (Fig. 8) weitergegeben. 

Fig. 11C zeigt analog zu Fig. 11B die Istfrequenz f, welche von dem 
Rotorstellungssensor 61 detektiert wird. An den Stellen 175, 177 und 179 
werden INT_MEAS_f und t_MEAS_J bestimmt. 

Anhand von Fig. 10, der Tabelle 1 und Fig. 11 wird nun die Frequenzmessung 
erlautert. Die Messungen der Sollfrequenz f__s und der Istfrequenz f laufen nach 
demselben Schema ab. Daher wird das Messprinzip zuerst anhand der 
Messung der Istfrequenz f erlautert. 

Messung der Istfrequenz f 

Zu dem in Fig. 11 beliebig gewahlten Zeitpunkt t = 0 befindet sich die 
Istwertmessung im Zustand S1. 

Bei jeder Flanke 110 (Fig. 4B) von f wird ein Hall-Interrupt 630 (Fig. 8) ausgelost. 
Dieser bewirkt folgendes: 

- Die Routine Hall-Interrupt S631 (Fig. 13) wird durch den Hall-Interrupt 630 
ausgelost, 
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- in der Routine Hall-Interrupt S631 wird der Zahler INTCNTJ fur die Anzahl 
der Flanken um einen Wert INC J, z.B. INC J = 1, erhoht (S322 in Fig. 13), 

. in der Routine Hall-Interrupt S631 wird der augenblickliche Wert des 
Ringzahlers TIMER1 gespeichert (S322 in Fig. 13). 

Auf dem Zustandsdiagramm (Fig. 10) ist dies dargestellt als Ubergang T1 von 
Zustand S1 zu SI. Das Ereignis ist hier ein durch eine Flanke 110 ausgeloster 
Hall-Interrupt 630, und die Aktion besteht in der Zahlung der Flanke 1 10 im 
Flankenzahler INTCNTJ, und der Speicherung des augenblicklichen Wertes 
des Ringzahlers TIMER1 . 

Ein anderes Ereignis lost den Ubergang T2 von Zustand S1 nach Zustand S2 
aus. Das Ereignis ist ein Auftreten eines durch den Timer TIMERO ausgelosten 
TIMERO-lnterrupts. TIMERO lost in vorgegebenen Abstanden T_A (Fig. 11 A) 
einen TIMERO-lnterrupt 638 aus, z.B. an den Stellen 161, 163, 165. In der 
zugehorigen Interruptroutine TIMERO-lnterrupt S639 (Fig. 8 und 12) werden d.e 
Istwertberechnung, Sollwertberechnung und der Regler freigegeben. TIMERO 
definiert aufeinanderfolgende Fenster mit der Breite T_A. 

lm folgenden soil die eigentliche Messung von INT_MEAS_f, t_MEAS_f 
stattfinden. Wie an den Stellen 175, 177 und 179 zu sehen ist, findet d.e 
jeweilige Messung nicht genau zu den Zeitpunkten 161, 163 und 165 der 
Anforderung statt, sondern zu einem geeigneten Zeitpunkt, welcher gewohnl.ch 
zeitlich etwas spater liegt als der Zeitpunkt der Anforderung. 

lm Zustand S2 werden weiterhin die Flanken 1 10 des Signals f erfasst, und es 
findet bei jeder Flanke 1 10 ein Ubergang T3 von S2 nach S2 analog zu T1 statt, 
in dem der augenblickliche Wert des Ringzahlers TIMER1 ausgelesen und 
gespeichert und der Flankenzahler INT.CNTJ erhoht wird. 

Zu der endgultigen Messung der Werte INT_MEAS_f und t_MEAS_f muss eine 
weitere Bedingung erfullt sein. Die Pole eines permanentmagnetischen, z.B. 
vierpoligen Rotors haben meistens nicht genau eine Erstreckung (Polbre.te) von 
90° mech sondern weichen leicht hiervon ab. Die Winkelsumme aller Polw.nkel 
ergibt jedoch immer 360° mech. Daher ist es vorteilhaft, z.B. bei einer Messung 
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mit Hallsensoren nur jede voile Umdrehung, also bei einem vierpoligen Rotor 
jede vierte Flanke, zu messen, da man so sicher sein kann, dass immer genau 
an derselben Stelle des Rotors 32 gemessen wird. Fur eine genauere Erklarung 
wird auf die Beschreibung zu Fig. 24 verwiesen. 

Die Anzahl der Flanken 110 des Signals f wird in der Variablen INT_CNT_f 
gezahlt, und die Bedingung, dass bei einem vierpoligen Rotor immer ein 
Vielfaches von ganzen Umdrehungen gemessen wird, kann gemaB der 
Beschreibung zu Fig. 24 und Gleichung (5) mit 

INT_CNT_f mod 4 = 0 (5') 
erreicht werden, oder alternativ mit 
INT_CNT_f mod 8 = 0, 

wobei im letzteren Fall immer fruhestens nach zwei vollen Umdrehungen, oder 
einem Vielfachen hiervon, gemessen wird. Bei INT_CNT_f mod 12 = 0 wurde 
fruhestens nach drei vollen Umdrehungen gemessen, etc. Hierdurch wurde 
jedoch die Dynamik eines Reglers verschlechtert. 

Bei einem sechspoligen Rotor wurde man dementsprechend z.B. mit INT_CNT_f 
mod 6 = 0 arbeiten, oder mit INT_CNT_f mod 12 = 0. 

Falls also die Anzahl der Flanken ein Vielfaches von MOD_f, hier MOD_f = 4 ist, 
findet in Fig. 10 ein Ubergang T4 von S2 nach S3 statt, die Anzahl der erfassten 
Flanken seit der letzten Messung, welche in INT_CNT_f gespeichert ist, wird in 
INT_MEAS_f gespeichert (S330 in Fig. 13), und der Zeitpunkt der aktuellen 
Messung wird in t_MEAS_f gespeichert. Die Werte INT_MEAS_f und t_MEAS_f 
werden daraufhin der Istdrehzahl-Berechung CALC_n S616 ubergeben, die in 
Fig. 15 dargestellt ist. 

Ist z.B. in Fig. 1 1 nach dem TIMERO-lnterrupt 163 bei der Istfrequenz f zum 
Zeitpunkt 177 ein Vielfaches von MOD_f = 4 Flanken erfasst worden, also hier 
z.B. 8 Flanken (8 mod 4 = 0), so wird die Anzahl der Flanken seit der letzten 
Messung zum Zeitpunkt 177 in INT_MEAS_f(175-177) und der Zeitpunkt 177 der 
aktuellen Messung in t_MEAS_f(177) gespeichert. 

Aus dem aktuellen Wert t_MEAS__f(177) und dem gespeicherten Wert 
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t_MEAS_f(175) der letzten Messung kann die fur die in der Variablen 
INT_MEAS_f(175-177) gezahlten Flanken benotigte Zeit At_MEAS_f(175-177) 

bestimmt werden. 

Eine alternative Moglichkeit, die Zeit At_MEAS_f zu bestimmen, liegt darin, die 
Zeit jeweils am Anfang einer Messung auf Null zuriickzusetzen. Dies kann z.B. 
durch Setzen des Timers TIMER1 auf Null erfolgen. Am Ende der Messung ent- 
spricht die Zeit dann dem Wert At_MEAS_f. Hierdurch liegt an den Stellen 175, 
177 und 179 direkt INT_MEAS_f und At_MEAS_f vor. Ein Nachteil des Zuruck- 
setzens von TIMER1 liegt darin, dass er dann schlecht gleichzeitig fur andere 
Messungen verwendet werden kann, so dass man ggf. weitere Zahler bendtigt, 
was aber im Rahmen der vorliegenden Erfindung nicht ausgeschlossen ist. 

Von Zustand S3, in welchem die letzte Messung abgeschlossen ist, fuhrt ein 
instantaner Obergang T5 zu dem Zustand S4, in welchem eine neue Messung 
beginnt. 

Vom Zustand S4 fuhrt ein instantaner Obergang T6 zu dem Zustand S1 , und die 
Frequenzmessung ist wieder im Ausgangszustand S1 . Wahrend T6 wird die 
nachste Messung vorbereitet. Es wird z.B. der Zahler INT_CNT_f (fur die Zahl 
der Flanken 110) wieder auf Null zuruckgesetzt. 

Messung der Sollfrequenz f_s 

Durch die TIMERO-lnterrupts 638 an den Stellen 161, 163 und 165 werden 
sowohl die Istfrequenzmessung als auch die Sollfrequenzmessung angefordert. 
Die Messung der Sollfrequenz f_s lauft ubereinstimmend mit der Messung der 
Istfrequenz ab, was auch aus den folgenden Flussdiagrammen ersichtlich ist. 

Die Variablen der Sollwerterlassung sind gleich benannt wie die der 
Istwerterfassung, sie haben jedoch eine Endung "_s" hinzugefugt, z.B. 
INT_MEAS_f_s anstelle von INT_MEAS_f. 

Auch bei einer Sollfrequenzvorgabe f_s kann es sinnvoll sein, ein Vielfaches 
einer festen Flankenzahl zu messen. So kann es z.B. innerhalb einer Periode 
der Sollfrequenz f_s zu Abweichungen kommen. Daher kann z.B. eine Messung 
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von jeweils mindestens zwei Flanken vorteilhaft sein. Der Flankenzahler 
INT_CNTJ_s muss dann mit INT_CNTJ_s mod 2 = 0 uberpruft werden. 

Die Messung gemaR Fig. 10 und 11 hat mehrere Vorteile. 

Bei interruptbasierten Messungen kann man zur Bestimmung der Drehzahl 
entweder bei jedem Interrupt Oder nach einer festen Anzahl von Interrupts die 
Zeit zum vorherigen Interrupt messen und daraus die Drehzahl berechnen. 
Hierdurch kommen bei immer hoher werdender Drehzahl immer haufiger neue 
Messwerte, welche verarbeitet werden mussen. Bei sehr hohen Drehzahlen 
wurde dies zu einer Uberlastung des jxC 23 und zur Nichtberucksichtigung von 
einzelnen Messwerten fuhren. 

Bei dem vorliegenden Messverfahren wird in vorgegebenen Abstanden T_A 
jeweils eine neue Messung eingeleitet. Der (iC 23 wird dadurch bei alien 
Drehzahlen bzw. Frequenzen gleich belastet. 

Weiterhin weist das vorliegende Verf dhren den Vorteil auf, dass bei der 
Messung des Signals f bzw. f_s mindestens bis zum nachsten Interrupt 
gemessen wird. So wird nicht zu irgendeinem Zeitpunkt, der z.B. in der Mitte 
zwischen zwei Flanken liegt, gemessen, sondern es wird immer von Flanke zu 
Flanke gemessen, was die Genauigkeit der Messung erheblich erhoht. 

Eine weitere Erhohung der Genauigkeit ergibt die Messung von jeweils einem 
Vielfachen von MOD_f bzw. MOD_f_s Flanken, da so z.B. Messfehler durch 
Magnetisierungsfehler bei einem permanentmagnetischen Rotor bzw. durch 
Symmetriefehler der Sollfrequenzvorgabe vermieden werden. Dies bedeutet 
z.B. bei einem vierpoligen Motor, dass eine Messung friihestens bei der vierten, 
8. oder 12. etc. Flanke erfolgt, namlich immer dann, wenn X mod 4 = 0 ist (bei 
einem vierpoligen Rotor werden pro Umdrehung vier Flanken 110 erzeugt). 

Ein weiterer groBer Vorteil liegt darin, dass jeweils nach Ablauf einer Zeit T_A 
sowohl die Istwert- als auch die Sollwertmessung gestartet wird, da so die 
Resultate beider Messungen der Reglerfunktion RGL praktisch gleichzeitig zur 
Verfugung stehen. Bei einer Messung nach jeder Flanke wurde das Signal mit 
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der hdheren Frequenz haufiger gemessen werden, was fur die 
Weiterverarbeitung weniger gunstig ware. 

AuBerordentlich vorteilhaft ist die Verwendung desselben Timers (TIMER 1) fur 
die Messung von f bzw. f_s, da eine Ungenauigkeit des Timers keine 
Ungenauigkeit bei dem Zeitverhaltnis der Messung von f bzw. f_s bewirkt. Die 
Frequenzen f und f_s werden so mit der gleichen Zeitschiene gemessen. Eine 
solche Messung ermoglicht in sehr vorteilhafter Weise eine frequenzgesteuerte 
Drehzahlregelung mit Getriebefunktion. Eine derartige Messung mit demselben 
Timer wird nachfolgend an einem Beispiel beschrieben. 

TIMER1 wird bevorzugt als Ringzahler ausgebildet, der standig lauft. 
Flussdiagramme zur Messung von f und f_s 

Die Fig. 12 bis 14 zeigen Flussdiagramme zu einem Programm fur die in Fig. 10 
und 1 1 beschriebene Messung. 

Fig. 12 zeigt die Routine TIMERO-lnterrupt S639 (Fig. 8), welche jeweils 
nach der Zeit T_A (Fig. 1 1) die Istwertmessung "MEAS f 147 (Fig. 7), die 
Sollwertmessung "MEAS f_s" 141 (Fig. 7) und den von RGL.ON S624 und RGL 
S628 (jeweils Fig. 8) gebildeten digitalen Drehzahlregler n-CTRL 35 (Fig. 1 und 
7) anfordert. 

Es werden folgende Variablen benutzt 

CNT_T_A Intemer Zahler fur die Zeit T_A 

T_A_TIME Grenzwert fur neue Messung 

DO_MEAS_f Flag zum Aufrufen der Istwertmessung 

DO_MEAS_f_s Flag zum Aufrufen der Sollwertmessung 

FCT_RGL_ON Funktionsregisterbit der Funktion RGL_ON S624 (vgl. Fig. 9). 

Bei jedem Auftreten eines TIMERO-lnterrupts 638 (Fig. 8) wird die TIMER0- 
Interruptroutine S639 ausgefuhrt, die in Fig. 12 dargestellt ist. 

In S352 konnen ggf. zusatzliche, hier nicht ausgefuhrte Schritte durchlaufen 
werden, falls durch den TIMERO auch andere Programmteile gesteuert werden 
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sollen. 

In S354 beginnt ein Subtimer Subtimer_T_A. Subtimer bedeutet, dass durch die 
im folgenden erlauterten Schritte S356, S358 und S362 die eigentliche Aktion in 
S360 erst nach einer bestimmten Anzahl von TIMERO-lnterrupts ausgelost wird. 
Dies hat den Vorteil, dass der Timer TIMERO auch fur andere Zwecke verwendet 
werden kann, welche haufiger aufgerufen werden mussen. 

In S356 wird der interne Zahler CNT_T_A um 1 erhoht. 

In S358 wird uberpruft, ob der Zahler CNT_T_A groRer oder gleich dem - oben 
definierten - Wert T_A_TIME ist. 

Falls nein, so wird sofort an das Ende S364 gesprungen, und die TIMERO- 
Interrupt routine wird mit dem Befehl "RETI" verlassen. 

Falls jedoch in S358 der Zahler CNT_T_A den Wert T_A_TIME erreicht hat, so 
werden in S360 DO_MEAS_f_s, DO_MEAS_f und FCT_RGL_ON auf 1 gesetzt. 

Mit DO_MEAS_f_s = 1 wird der Interruptroutine f_s-lnterrupt S635 (Fig. 14) 
mitgeteilt, dass eine Messung der Sollfrequenz f_s gestartet werden soli. Mit 
DO_MEAS_f = 1 wird der Interruptroutine Hall-Interrupt S631 (Fig. 13) mitgeteilt, 
dass eine Messung der Istfrequenz f gestartet werden soli. Mit FCT_RGL = 1 wird 
die Startfunktion RGL_ON S624 (Fig. 17) gestartet, welche bestimmt, wann die 
Reglerfunktion RGL S628 (Fig. 18) gestartet wird. 

Ein Beispiel: Wenn der TIMERO-lnterrupt alle 10 jis ausgelost wird und der Wert 
T_A_TIME = 2500 ist, findet der Aufruf in S360 alle 25 ms statt. 

Die Zeit T_A muss an den jeweiligen Motor angepasst werden. Produziert der 
Rotorstellungssensor 61 z.B. viele Ereignisse pro Umdrehung des Rotors 32, 
und dreht der Rotor 32 schnell, so kann T_A kiirzer gewahlt werden. Dreht der 
Rotor 32 jedoch langsam, so muss T_A langer, z.B. T_A = 250 ms, gewahlt 
werden. Die Frequenz f_s muss in der gleichen Weise berucksichtigt werden. 
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ln S362 wird der Zahler CNT_T_A wieder auf Null zuriickgesetzt, urn den 
Subtimer Subtimer_T_A neu zu starten. 

In Fig. 1 1 findet der Aufruf von S360 an den Stellen 161 , 163 und 165 start. 

Fig. 13 zeigt ein Ausfuhrungsbeispiel fur die Interruptroutine Hall-Interrupt 
S631 welche bei jedem durch das Auttreten einer Flanke 110 (Fig. 4B) des 
Signals f ausgelosten Interrupt ausgefiihrt wird. Dieser Interrupt wird so bezeich- 
net, weil er gewdhnlich durch das Signal eines Hallgenerators 61 ausgelost 
wird. Fig. 29 zeigt ein Beispiel hierfur. Selbstverstandlich konnte er ebenso 
durch das Signal eines optischen oder mechanischen Sensors ausgelost 
werden, und man konnte ihn auch als sensorgesteuerten Interrupt bezeichnen. 

Die Routine Hall-Interrupt S631 sorgt bei diesem Beispiel in den Schritten S304 
bis S314 fur die Kommutierung eines elektronisch kommutierten Motors 32, und 
in den Schritten S320 bis S332 fur die Messung der Istfrequenz f. 

Es werden folgende Variablen benutzt 

INT_CNT_f Interruptzahler fur die Erfassung der Flanken des Signals f 
lNC_f Inkrementwert 

t_END_f Zeitpunkt des letzten Interrupts der Erfassung 

MOD_f Anzahl der Interrupts fur mod-Berechnung, vgl. Gleichung (5a) 

t_MEAS__f Gemessene Zeit des letzten Interrupts 

INT_MEAS_f Zahl der gemessenen Interrupts seit der letzten Messung 

DO_MEAS_f Flag zum Aufrufen der Istwertmessung 

FCT_CALC_n Funktionsregisterbit der Funktion CALC.n S616 (Fig. 8 und 9) 
In S302 konnen beliebige Schritte ausgefiihrt werden. 

Die Routine Hall-Interrupt S631 sorgt bei einem elektronisch kommutierten 
Motor (ein solcher ist in Fig. 29 schematisch dargestellt) in COMMUT S304 fiir 
die elektronische Kommutierung. Diese entfallt bei einem Kollektormotor, wie er 
in Fig. 6 dargestellt ist. 

In S306 wird mit HALL = 1 uberpruft, ob das Signal f (Fig. 4B) auf HIGH ist. Falls 
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ja, so wird in S308 der Anschluss B5 des |uC 23 (Fig. 3) so eingestellt, dass er 
bei der nachsten Flanke von HIGH nach LOW einen Interrupt auslost. (Alternativ 
ist auch ein sogenannter Interrupt on Change moglich, d.h. bei jeder Flanke des 
Signals HALL am Port B5, egal in welcher Richtung, findet ein Interrupt start.) In 
S310 findet schlie3lich die Kommutierung des Motors M 32 start, indem OUT1 
auf 1 und OUT2 auf 0 gesetzt wird. War in S306 HALL = 0, so wird in S312 der 
Anschluss B5 auf eine umgekehrte Flanke eingestellt, und in S314 wird OUT1 
auf 0 und OUT2 auf 1 gesetzt. Die Kommutierung mit den beiden Signalen 
OUT1 und OUT2 wurde bereits bei Fig. 29 ausfuhrlich beschrieben. 

In MEAS_f S320 beginnt die Erfassung und Messung des Signals f. In S322 
wird der Interruptzahler INT_CNT_f , welcher z.B. 1 Byte groB ist, um den Wert 
INC J, z.B. INC_f = 1 , erhoht, und der Wert t_TIMER1 von TIMER1 wird in 
t_END_f gespeichert. Damit sind sowohl die Anzahl der Interrupts als auch die 
momentane Zeit erfasst. 

In S324 wird mit INT_CNTJ mod MOD_f = 0 uberpruft, ob der Wert im Interrupt- 
zahler INT_CNTJ ein Vielfaches von MOD_f ist. Bei MOD_f = 4 ist z.B. 
INT_CNTJ = 20 ein Vielfaches von MOD_f, also 20 mod 4 = 0. Falls INT_CNT_f 
nicht ein Vielfaches von MOD_f ist, so wird an das Ende S334 der Interrupt- 
routine gesprungen. Falls INT_CNT_f ein Vielfaches von MOD_f ist, so wird in 
S326 uberpruft, ob DO_MEAS_f = 1 ist, ob also in dem Schritt S360 der Inter- 
ruptroutine TIMERO- Interrupt S639 (Fig. 12) eine Messung der Istfrequenz f 
angefordert wurde. Falls nein, soli noch nicht gemessen werden, und es wird an 
das Ende S334 gesprungen. Falls ja, so wird in S328 anhand des Funktionsre- 
gisterbits FCT_CALC_n uberpruft, ob die letzte Drehzahlberechnung bereits 
abgeschlossen ist. Falls FCT_CALC_n = 1 ist, so wird an das Ende S334 
gesprungen. Dies verhindert, dass Messungen verlorengehen, wenn die 
Drehzahlberechnung "CALC_n H S616 zu viel Zeit benotigt. Dieser Sonderfall tritt 
jedoch im normalen Betrieb nicht auf. 

In S330 werden die Variablen t_MEAS_f und INT_MEAS_f gesetzt, welche der 
Drehzahlberechnung CALC_n S616 (Fig. 15) ubergeben werden. 

Hierzu wird t MEAS f auf den letzten erfassten Timerwert t END f des 
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Ringzahlers TIMER1 gesetzt, INT.MEAS J wird auf den Wert des 
Interruptzahlers INT.CNTJ gesetzt, und INT.CNTJ wird auf Null zuruckgesetzt. 

In S332 wird die Drehzahlberechnung CALC.n S616 (Fig. 15) durch Setzen 
von FCT_CALC_n auf 1 angefordert, und die Messanforderung wird durch 
Zuriicksetzen von DO_MEAS_f auf Null zuruckgesetzt, da die Messung 
abgeschlossen ist. 

Die Routinen TIMERO-lnterrupt S639 (Fig. 12) und HALL-lnterrupt S631 (Fig. 13) 
bilden somit zusammen eine Messung der Istfrequenz f gemaB dem 
Zustandsdiagramm der Fig. 10. 

Falls der uO 23 die Operation mod nicht beherrscht, bestehen andere 
Mdglichkeiten. 

Bei vielen uCs ergibt eine ganzzahlige Division mit div als Ergebnis sowohl den 
ganzzahligen Quotienten als auch den nicht-negativen Rest. So ergibt z.B. 7 div 
4 als Ergebnis den Quotienten 1 und den Rest 3. Bei solchen uCs kann die 
Operation div zur Berechnung des Restes verwendet werden. 

Eine weitere Moglichkeit der Berechnung von X mod MODJ besteht z.B. in der 
Verwendung einer weiteren Variablen MOD_CNT, welche bei jeder Erhohung 
der Variablen X ebenfalls erhdht wird, und welche bei Erreichen von MODJ 
jeweils auf Null zuruckgesetzt wird. Die Variable MOD_CNT enthalt dann das 
Ergebnis von X mod MODJ. 

Fig. 14 zeigt ein Beispiel fur die Interruptroutine f_s-lnterrupt S635. 

Diese ist bis auf das Fehlen des Kommutierungsteils (Schritte S304 bis S314 
der Fig. 13) wie die Interruptroutine HALL-lnterrupt S631 (Fig. 13) aufgebaut, 
und sie wird deshalb nicht nochmals beschrieben. Die Bezugszeichen der 
Schritte sind urn 100 erhoht, so dass z.B. der Schritt S332 aus Fig. 13 dem 
Schritt S432 aus Fig. 14 entspricht. 



Es werden folgende Variablen benutzt 
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INT_CNT_f_s 
INC_f_s 
t_END_f_s 
MODJ_s 
t MEAS f s 



Interruptzahler fur die Erfassung der Flanken der Sollfrequenz 
Inkrementwert 

Zeitpunkt des letzten Interrupts der Erfassung 
Anzahl der Interrupts fur mod-Berechnung 
Gemessene Zeit des letzten Interrupts 
I NT_MEAS_f_s Anzahl der Interrupts seit der letzten Messung 
DO_MEAS__f_s Flag zum Aufrufen der Sollwertmessung 
FCT_CALC_n_s Funktionsregisterbit fur die Funktion CALC_n_s S620 



Fig. 15 zeigt die Routine CALC_n S616, welche nach der Messung des 
Timerwerts t_MEAS_f und der Anzahl der Flanken 110 (Fig. 4) des Signals f in 
INT__MEAS_f durch die Routine Hall-Interrupt (S332 in Fig. 13) angefordert wird. 

Es werden folgende Variablen benutzt 
At_CALC_f Zeitdifferenz zur letzten Messung 
t_OLD_f Zeitpunkt der letzten Messung 
t_MEAS_f Zeitpunkt der momentanen Messung 

INT_CALC_f Anzahl der Interrupts seit der letzten Messung fiir die Berechnung 

INT_MEAS_f Ubergebene Anzahl der Interrupts seit der letzten Messung 

n Drehzahl des Motors M 

REM_n Rest der ganzzahligen Division 

h Hochzahl fur Parametrierung von INT_CALC_f 

REM_n_OLD Rest der ganzzahligen Division der letzten Berechnung 

In S370 wird die Differenz zwischen dem Timerwert t_OLD_f der letzten Mes- 
sung und dem aktuellen Timerwert t_MEAS_f berechnet und in der Variablen 
At_CALC_f gespeichert, welche dem Wert At_MEAS_f aus Fig. 1 1 entspricht. Die 
Differenz wird bei einem Ringzahler ublicherweise mit Hilfe des Zweierkomple- 
ments gebildet. Der aktuelle Timerwert t_MEAS_f wird daraufhin fur die nachste 
Messung in t_OLD_f gespeichert, und die gemessene Anzahl der Interrupts 
INT_MEAS_f wird in INT_CALC_f gespeichert. 

In S372 geschieht die Berechnung der Drehzahl n. Diese ist proportional zu 
dem Quotienten aus der Zahl der Interrupts INT_CALC_f, einem MaB fiir die 
Anzahl der Umdrehungen, und der hierfur benotigten Zeit At_CALC_f. Es gilt 



WO 01/22095 



PCT/EPOO/07622 



-37- 

n = const * INT_CALC_f / At_CALCJ < 6) 
const ist eine Proportionalitatskonstante. 

Fur die Berechnung der Drehzahl n wird eine ganzzahlige Division div 
verwendet, welche als Ergebnis den ganzzahligen Quotienten n und den 
positiven Rest REM_n ergibt. Fur eine Beschreibung des Operators div s.ehe 

Fig. 13. 

Weiterhin wird der Interruptzahler INT_CALCJ, welcher in diesem 
Ausfuhrungsbeispiel z.B. 4 Byte groB ist, mit einem Faktor 2 a h, z.B. h = 24, 
parametriert. Es kann anstelle von 2 a h naturlich jeder andere Faktor gewahlt 
werden. Die Multiplikation mit 2 a h kann jedoch in binarer Darstellung bevorzugt 
durch eine Verschiebung des Wertes urn h Stellen nach links ersetzt werden. 

Durch die Parametrierung werden die sich durch die Division ergebenden 
Drehzahlen n z.B. in 16 Bit gut aufgelost. Der Exponent h muss hierzu auf den 
jeweiligen Motor abgestimmt werden. 

Als Beispiel folgt die Berechnung der Drehzahl fur den Bereich zwischen den 
Stellen 175 und 177 aus Fig. 11: 

INT_MEAS_f ist ein Byte groB, INT_CALC_f vier Byte und At.CALCJ zwei Byte. 

INT_MEAS_f(175-177) hat hier den Wert 8, es wurden also seit der letzten 
Messung zum Zeitpunkt t_MEASJ(1 75) acht Flanken 1 1 0 des Signals f (Fig. 
11C) gezahlt. INT.CALCJ bekommt in S370 den Wert INT_MEAS_f(175-177) - 
8 zugewiesen. In S372 wird INTCALCJ bei h = 19 mit 2 a 19 = 524.288 
parametriert und erhalt den Wert 4.194.304. 

At_MEAS_f(175-177) hat den Wert 26.700, welcher bei einer Auflosung des 
Ringzahlers TIMER1 von 1 us einer Zeit von 26,7 ms entspricht. At_CALC_f 
bekommt in S370 den Wert 26.700, welcher sich aus der Differenz zwischen 
alter und momentaner Messung ergibt, zugeordnet. 

Die Division von lNT_CALC_f durch At_CALC_f ergibt die Drehzahl n = 157 und 
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den Rest REM_n = 2404. 

Die physikalische Drehzahl n_phys entspricht der Anzahl der Umdrehungen pro 
Minute. Aus 8 Hallwechseln geteilt durch 4 Hallwechsel pro Umdrehung 
(vierpoliger Rotor) ergeben sich 2 Umdrehungen, und die hierfur benotigte Zeit 
betragt 0,0267 s. Damit ergibt sich eine physikalische Drehzahl n_phys = 2 / 
0,0267 U/s = 74,906 U/s = 4494,4 U/min. 

In der Berechnung wird auch der Rest REM_n_OLD der vorhergehenden 
Drehzahlberechnung durch Addition zu dem Produkt aus INT_CALC_f und 
consM berucksichtigt. 

In dem obigen Beispiel weicht z.B. die berechnete Drehzahl n von der 
tatsachlichen Drehzahl etwas ab, da die Division die ganze Zahl 157 anstelle 
des eigentlichen Ergebnisses von ca. 157,09 ergibt. Die Differenz geht jedoch 
nicht verloren, sondern sie wird bei der folgenden Division in S372 durch die 
Addition des Restes REM_n_OLD der letzten Division zum Zahler (Englisch: 
numerator) berucksichtigt. 

Durch die Berucksichtigung des Restes REM_n_OLD wird in vorteilhafter Weise 
erreicht, dass keine Information verlorengeht, und sie fuhrt zu einer messbaren 
Verbesserung des Reglers, sofem sie verwendet wird. 

Nach der Berechnung von n und REM_n wird in S372 der Rest REM_n in 
REM_n_OLD fur die nachste Berechnung gespeichert. 

In S374 wird das Funktionsregisterbit FCT_CALC_n (Fig. 9; Fig. 13, S332) 
wieder auf Null zuruckgesetzt, da die Drehzahlberechnung abgeschlossen ist. 

Daraufhin wird an den Anfang S602 des Funktionsmanagers (Fig. 8) 
gesprungen. 

Fig. 16 zeigt ein Flussdiagramm zur Berechnung der Solldrehzahl n_s. 
Es werden folgende Variablen benutzt 
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t_CALC_f_s 
t OLD f s 



Zeitdifferenz zur letzten Messung 
Zeitpunkt der letzten Messung 



t_MEAS_f_s Zeitpunkt der momentanen Messung 
INT_CALC_f_s Anzahl der Interrupts seit der letzten Messung fur die 

Berechnung 

INT_MEAS_f_s Ubergebene Anzahl der Interrupts seit der letzten Messung 



REM_n_s_OLD Rest der ganzzahligen Division der letzten Berechnung 

Die Berechnung der Solldrehzahl n_s ist identisch mit der Berechnung der 
Drehzahl n gemaB Fig. 15. Die Bezugszeichen der Fig. 16 entsprechen den urn 
100 erhohten Bezugszeichen der Fig. 15. Der Wert h_s zur Parametrierung von 
INT_CALC_f wird im Normalfall gleich dem Wert h aus Fig. 15 gewahlt, da die 
Solldrehzahl und die Istdrehzahl vergleichbar sein sollen. Durch eine Wahl von 
h_s ungleich h konnte eine relative Parametrierung stattfinden, welche jedoch 
im Normalfall nicht gewahlt wird. 

Die Schritte von Fig. 16 werden nicht nochmals beschrieben, um unnotige 
Langen zu vermeiden. Auf Fig. 15 und die zugehorige Beschreibung wird 
verwiesen. 

Da die Messung der Sollfrequenz f_s und der Istfrequenz f in der gleichen Weise 
und quasiparallel ablauft, hat man nach jeder durch den TIMERO-lnterrupt 
ausgelosten Messung einen Wert fur die Solldrehzahl n_s und einen Wert fur 
die Drehzahl n. Die Werte n und n_s sind vergleichbar, da die Zeiten mit Hilfe 
desselben Timers TIMER1 und praktisch gleichzeitig gemessen wurden. 
Aufgrund der verwendeten Messmethode sind sie zudem sehr genau. 

Gesamtregler 

Start des Reglers durch die Funktion RGL_ON 

Fig. 17 zeigt ein Flussdiagramm fur ein Ausfuhrungsbeispiel der Funktion 

RGL_ON S624 der Fig. 8, welche bestimmt, wann die Reglerfunktion RGL S628 



n s 



REM_n_s 
h s 



Solldrehzahl (gewunschte Drehzahl des Motors M) 

Rest der ganzzahligen Division 

Hochzahl fur Parametrierung von INT_CALC_f_s 
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(Fig. 18) gestartet wird. 



Da die Erfassung und Messung der Istfrequenz f und der Sollfrequenz f_s und 
damit auch die Berechnung der Drehzahl n und Solldrehzahl n_s unabhangig 
voneinander ablaufen und nicht zum gleichen Zeitpunkt enden, muss in der 
Funktion RGL_ON S624 bestimmt werden, wann die Reglerfunktion RGL S628 
gestartet wird. In diesem Ausfuhrungsbeispiel wird die Reglerfunktion RGL S628 
gestartet, wenn sowohl die Istdrehzahlberechnung CALC_n S616 als auch die 
Solldrehzahlberechnung CALC_n_s S620 abgeschlossen sind. 

Es werden folgende Variablen benutzt 

FCT_CALC_n_s Funktionsregisterbit fur die Funktion CALC_n_s S620, vgl. 

Fig. 9 

FCT_CALC_n Funktionsregisterbit fur die Funktion CALC_n S616, vgl. Fig. 9 
FCT_RGL Funktionsregisterbit fur die Funktion RGL S628, vgl. Fig. 9 

FCT_RGL_ON Funktionsregisterbit fur die Funktion RGL_ON S624, vgl. Fig. 9 

In S390 wird anhand des Funktionsregisterbits FCT_CALC_n_s uberpruft, ob 
die Solldrehzahlberechnung CALC_n_s S620 fertig ist. Falls nein, so wird 
zuruck zum Anfang S602 des Funktionsmanagers (Fig. 8) gesprungen. Falls ja, 
so wird in S392 anhand des Funktionsregisterbits FCT_CALC_n uberpruft, ob 
die Drehzahlberechnung CALC_n S616 abgeschlossen ist. Falls nein, so wird 
zuruck zum Anfang S602 des Funktionsmanagers gesprungen. Falls ja, so 
liegen sowohl die Drehzahl n als auch die Solldrehzahl n_s vor, und die 
Reglerfunktion RGL S628 wird durch Setzen des Funktionsregisterbits FCT_RGL 
auf 1 angefordert. Das Funktionsregisterbit FCT_RGL_ON wird auf Null 
zuruckgesetzt, da die Funktion RGL_ON S624 abgearbeitet ist. 

Es wird also mit dem Start der Reglerfunktion RGL S628 gewartet, bis die 
Solldrehzahl n_s und die Drehzahl n berechnet sind. 



Reglerfunktion RGL mit "elektronischem Getriebe" 
Fig. 18 zeigt ein Flussdiagramm fur eine Ausfuhrungsform der Reglerfunktion 
RGL S628 (Fig. 8), welche aus der Drehzahl n und der Solldrehzahl n_s einen 
Stellwert RGL_VAL berechnet und diesen ausgibt. 
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Es werden folgende Variablen benutzt 



RGL_ 


.DIFF 


Regelditterenz 


X 




Getriebefaktor 


RGL_ 


PROP 


Proportionalanteil 


RGL_ 


P 


Proportionalfaktor 


RGL 


J NT 


Integralanteil 


RGL_ 


J 


Integralfaktor 


RGL. 


_VAL 


Vom Regler berechneter Stellwert 


RGL 


MAX 


Maximaler Stellwert 



In S530 wird die Regeldifferenz RGL__DIFF als 

RGLJDIFF: = n_s * X - n (7) 
berechnet. 

Durch die Multiplikation der Solldrehzahl n_s mit X wird eine Getriebefunktion 
verwirklicht. Mit X = 2 wird z.B. erreicht, dass die Solldrehzahl n_s der halben 
gewunschten Drehzahl n des Motors 32 entspricht, oder anders gesagt, dass der 
Motor M genau doppelt so schnell lauft wie der Sollwert n_s, und mit X = 1/2 wird 
z.B. erreicht, dass die Solldrehzahl n_s der doppelten Drehzahl n entspricht, d.h. 
der Motor M dreht sich mit dem halben Wert der Drehzahl, die durch n_s 
vorgegeben wird. Dies wird an einem Zahlenbeispiel nachfolgend erlautert. 

Die Drehzahl n und die Solldrehzahl n_s werden durch diesen Schritt in ein 
bestimmtes Verhaltnis 

n / n_s = X (8) 
gesetzt. Fur die Istfrequenz f und die Sollfrequenz f_s bedeutet dies ebenfalls 
ein testes Verhaltnis, z.B. 

f _s / f = y/z (1) 
wie in Fig. 1 erlautert. 

Wie sich aus S530 direkt ergibt, konnte man die Regeldifferenz auch anders 
berechnen, z.B. nach der Gleichung 

RGLJDIFF: = n_s - Y * n (7a), 
wie das in Fig. 7 bei 145' angedeutet ist, 
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Oder nach der Gleichung 

RGL_DIFF: = A * n_s - B * n (7b), 
oder unter Verwendung einer geeigneten mathematischen Funktion, z.B. 
In(n_s), oder einer Funktion der Zeit, z.B. 

RGL_DIFF: = (n_s * sin t) - n (7c) f 
wobei dann die Drehzahl zwischen der positiven Drehzahl n_s und der 
negativen Drehzahl -(n_s) periodisch oszillieren wurde. Selbstverstandlich setzt 
dies einen Motor voraus, der in beiden Drehrichtung laufen kann. Ein solcher 
Motor 32 M ist als Beispiel in Fig. 29 dargestellt. Die meisten elektronisch 
kommutierten Motoren laufen in beiden Drehrichtungen und eignen sich fur 
solche Anwendungen. 

Ebenso kann ein Getriebefaktor eingefuhrt werden, indem man z.B. bei der 
Sollfrequenz f_s nur jedes zweite "Ereignis" zahlt, und dasselbe gilt analog fur 
die Istfrequenz f. Da numerische Werte miteinander verglichen werden, ist jede 
Art von bekannter mathematischer Manipulation dieser numerischen Werte 
moglich, wobei sich im einzelnen immer wieder besondere Vorteile ergeben 
werden. 

Im folgenden werden einige weitere Moglichkeiten der Ausfuhrung eines 
"elektronischen Getriebes" dargestellt und erlautert. 

Die Multiplikation von n_s mit X kann z.B. als Festkomma-Multiplikation 
ausgefuhrt werden. Bei der Festkomma-Multiplikation wird bei der Variablen X 
an einer festen Stelle ein Komma angenommen, so dass die Bits rechts von dem 
Komma einer Multiplikation mit 1/2, 1/4 etc. entsprechen. Der Vorteil der 
Festkomma-Multiplikation ist, dass keine Nachkommastellen verlorengehen. 

Zahlenbeispiel 

Vom Sollwertgeber 20 (Fig. 1) wird eine Frequenz f_s zugefuhrt, die einer Solldrehzahl von 
3000 U/min entspricht. Der Motor 32 soli jedoch mit einem Getriebefaktor X laufen, der 0,5 
betragt, also mit 1500 U/min. 

Aus der Frequenz f_s wird in Fig. 7 im Teil 143 (entspricht den FluBdiagrammen der Fig. 14 
und 15) eine Solldrehzahl n_s von 3000,00 U/min berechnet. Intern wird im Rechner - 
wegen der hoheren Genauigkeit - die Zahl 300.000 verwendet, was hexadezimal der Zahl 
493E0 entspricht. Diese Zahl wird mit dem Getriebefaktor X = 0,5 multipliziert, und man 
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erhalt folglich als Sollwert X * n_s den hexadezimalen Wert 249F0. 

Der Motor 32 dreht sich im Augenblick mit 1499,99 U/min. Im Rechner wird - wegen der 
hoheren Genauigkeit - die Zahl 149.999 verwendet, und zwar als hexadezimale Zahl 
249EF. Dies entspricht in Fig. 7 der tatsachlichen Drehzahl n. 

Im Differenzbildner 151 wird nun gemaB S530 (Fig. 18) die Regeldifferenz RGLJDIFF 
gebildet, also 

n_s * X - n = 249F0 - 249EF = 1 [dezimal] 

(Der Wert 1 ist im Dezimalsystem angegeben, urn die Verstandlichkeit zu erhohen). 
Da die Werte fur X * n_s und n in diesem Beispiel zuvor mit 100 multipliziert worden waren, 
muss dieser Wert wieder durch 100 dividiert werden, d.h. der tatsachliche Wert der 
Regeldifferenz betragt 1/100 = 0,01 U/min. 

Dieser numerische Wert wird gemaB S532 (Fig. 18) im Pl-Regler weiterverarbeitet, und da 
die Drehzahl etwas zu niedrig ist, wird die GroBe RGL_VAL durch den Pl-Regler erhoht, urn 
die Drehzahl auf exakt 1500 U/min zu bringen. Durch die Schritte S534 bis S540 wird die 
GroBe RGL_VAL innerhalb der zulassigen Grenzen 0 und RGL_MAX gehalten. 

Obwohl also als Frequenz f_s ein Sollwert von 3000 U/min vorgegeben wird, wird der 
Motor auf 1500 U/min geregelt, da ein u Getriebefaktor ,, X von 0,5 eingestellt ist. In der 
gleichen Weise konnte auch ein anderer Getriebefaktor eingestellt werden, z.B. 0,333, und 
der Motor wurde dann auf 1000 U/min geregelt werden. 

Aus dem Beispiel sieht man auch, dass man ebensogut den Wert fur n_s unverandert 
lassen konnte, und dafur den Wert fur n bei diesem Beispiel mit 2 multiplizieren konnte. Der 
Wert fur die Regeldifferenz wurde dann doppelt so groB, aber der Ablauf des 
Regelvorgangs ware derselbe. 

Das Verhaltnis n / n_s kann - zusatzlich oder alternativ - auch bei der 
Frequenzmessung und Drehzahlberechnung beeinflusst werden, indem z.B. die 
Variablen h (S372 in Fig. 15) und h_s (S472 in Fig. 16) unterschiedlich gewahlt 
werden. 

Auch die Berucksichtigung des Wertes von MOD_f bei der Messung der 
Istfrequenz f (S324 in Fig. 13) und des Wertes von MOD_f_s bei der Messung 
der Sollfrequenz f_s (S 424 in Fig. 14) kann eine Anderung des Verhaltnisses 
der Frequenzen f und f_s und damit auch der Drehzahlen n und n_s bewirken. 

Der Ort, an dem das gewunschte Verhaltnis der Drehzahlen n und n_s bzw. der 
Frequenzen f und f_s gebildet wird, ist fur die vorliegende Erfindung nicht von 
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Bedeutung. Das Verhaltnis muss aber an einer geeigneten Stelle gebildet 
warden. 

In S352 der Fig. 18 ist ein digitaler Pl-Regler dargestellt. 

Der Proportionalanteil RGL_PROP wird durch Multiplikation der Regeldifferenz 
RGLJDIFF mit dem Proportionalfaktor RGL_P berechnet. 

Der neue Integralanteil RGLJNT wird durch Addition des vorhergehenden 
Integralanteils zu der mit dem Integralfaktor RGLJ multiplizierten Regeldifferenz 
RGL_DIFF berechnet. Bevorzugt steht dem Integralanteil RGLJNT so viel 
Speicher zur Verfugung, dass keine Information der Regeldifferenz verloren 
geht. 

Der Stellwert RGLJ/AL ergibt sich aus der Summe des Proportionalanteils 
RGL_PROP und des Integralanteils RGLJNT. 

In den Schritten S534 bis S540 wird eine Bereichsuberprufung des Stellwerts 
RGLJ/AL durchgefuhrt. 

Ist der Stellwert RGL_VAL in S534 kleiner als Null, so wird er in S536 auf Null 
gesetzt. 

Ist der Stellwert RGLJ/AL in S538 groBer als der maximal zulassige Wert 
RGL_MAX, so wird er in S540 auf RGLJVIAX gesetzt. Dies dient dazu, beim 
Hochlauf eines Motors, wo groRe Regeldifferenzen vorliegen konnen, den 
Stellwert RGL_VAL auf den Maximalwert RGLJMAX zu begrenzen. 

Liegt der Wert von RGL_VAL innerhalb eines zulassigen Bereichs, so wird er 
unverandert verwendet. 

In S542 wird das Register PWM_SW des jaC-internen PWM-Generators auf den 
Stellwert RGL_VAL gesetzt, und das PWM-Signal PWM^SW wird, wie bei Fig. 5 
beschrieben, ausgegeben. 
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Die Reglerfunktion S628 ist damit abgearbeitet, und das Funktionsregisterbit 
FCT_RGL wird in S544 zuruckgesetzt. 

Daraufhin wird an den Anfang S602 des Funktionsmanagers (Fig. 8) 
zuriickgesprungen. 

Statt des beschriebenen Pl-Reglers konnte z.B. auch ein PID-Regler oder ein 
anderer Regler verwendet werden. Vorteilhafl sind digitale Regler, bei denen 
alle Bits der Regeldifferenz RGL_DIFF beriicksichtigt werden, was hier durch 
den Integralanteil RGL_INT gewahrleistet wird. Die Reglerfaktoren RGL_P und 
RGLJ konnen getrennt eingestellt werden, urn den Regler optimal an die 
jeweilige Aufgabe anzupassen. 

Fig. 19 zeigt ein Zustandsdiagramm, welches die beschriebenen komplexen 
Funktionsablaufe der vorhergehenden Figuren in einfacher und verstandlicher 
Weise zusammenfasst. Die nachfolgende Tabelle 2 gibt die erforderlichen 
Erlauterungen zu diesem Zustandsdiagramm und ist weitgehend 
selbsterklarend. WDT bedeutet Watch Dog Timer. 
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Ubergang 


| Ereignis 


Aktion 
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' ->M 

I 
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T21 


| Watchdog-Timer Reset 

1 
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< 

i * m 

1 ->M 
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T22 
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; ohne Ereignis 
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T23 


Unmittelbarer 
Zustandswechsel 
ohne Ereignis 


Initialisierung. Ggf. Holen 
von Parametern aus 
EEPROM 80 


1 

N->0 j 

i 


T24 


Berechnung Istwert 
gestartet 

i 


►~ — ■ 

Berechnung Istwert 

ausfuhren. Zahler 

INT_CALCJ rucksetzen. 

Berechnuna Istwert 

stoppen und sperren. 


■ o~>o 


T25 


Berechnung Sollwert 
gestartet 

1 


Berechnung Sollwert 
ausfuhren. Zahler 
INT_CALCJ_s 
rucksetzen. 
Berechnung Sollwert 
stoppen und sperren. 


o -> o !i 


T26 


Berechnung von 
Sollwert und Istwert 
gestoppt. Regler 
freigegeben. | 


Regler starten 


o->o 


|T27 

I 
i 


Regler gestartet 


S530 (X * n_s) | 
Regler RGL (Fig. 18) 
S542 (Stellwertausgabe) ' 
S544 (Regler stoppen 
und sperren) 


o->o 

li 



Inn Zustand O (Idle) ist das Programm aktionsbereit und fiihrt je nach Bedarf 
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verschiedene Aktionen durch. Bei T24 wird z.B. die Berechnung des Istwerts 
Frequenz ausgefuhrt, der Zahler INT_CALC_f wird riickgesetzt, und 
anschlieBend wird die Istwertberechnung so lange gesperrt, bis eine neue 
Messung durchgefuhrt worden ist. Beim Ubergang T25 werden dieselben 
Aktionen fur den Sollwert ausgefuhrt. 



Bei T26 werden die Berechnungen von Soil- und Istwert gestoppt, und der 
Regler RGL (Fig. 18) wird gestartet. Bei T27 ist dann der Regler gestartet. Im 
Schritt S530 wird die Getriebeiibersetzung X berucksichtigt. Die Berechnungen 
im Pl-Regler werden ausgefuhrt, der Stellwert wird in S542 ausgegeben, und in 
S544 wird der Regler gestoppt und vorlaufig gesperrt, bis nach der nachsten 
Messung neue Werte vorliegen. 

Die Zustande M und N werden gewohnlich nur beim Einschalten durchlaufen, 
da dann ein Hardware-Reset stattfindet. Wenn der Watchdog (nicht dargestellt) 
ein unregelmaBiges Verhalten des uC 23 feststellt, werden die Aktionen T21 , 
T22 und T23 abgearbeitet, urn den |xC 23 wieder in seinen normalen 
Betriebszustand O zu versetzen. 

Beispiel fur einen Regler mit moglicher Solldrehzahl n_s ■ 0 
Fig. 20 zeigt ein Zustandsdiagramm fur einen Regler, bei welchem auch die 
Solldrehzahl n_s = 0 eingestellt werden kann. 

Die Funktion RGL_ON S624 aus Fig. 17 wartet mit dem Start der Reglerfunktion 
RGL S628, bis ein Wert sowohl die Solldrehzahl n_s als auch die Drehzahl n 
vorliegt. 

Dies bereitet bei Motoren, welche auch auf die Drehzahl n = 0 heruntergeregelt 
werden sollen, Schwierigkeiten, da, wenn die Signale f bzw. f_s die Frequenz 
Null haben, keine Interrupts ausgelost werden, da keine Flanken der Signale f 
bzw. f_s vorliegen. 



Der Regler aus Fig. 21 ermoglicht eine Regelung auf die Drehzahl Null, und 
stellt daher eine bevorzugte Weiterbildung dar. 
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Das Zustandsdiagramm enthalt sechs Zustande S10 bis S15 und neun 
Ubergange T10 bis T18. 

In der folgenden Tabelle 3 sind die Ubergange T10 bis T18 mit den 
zugehorigen Ereignissen und Aktionen beschrieben. Diese Tabelle ist, ebenso 
wie die Tabellen 1 und 2, aus sich selbst heraus verstandlich. 



Ubergang 


Ereignis Aktion 


T10 


Der Regler wurde durch RGL_ON wird gestartet, 
TIMERO-lnterrupt gestartet Sprung zu S1 1 


T11 


Solldrehzahl n_s liegt vor Sprung zu S12 


T12 


Time-Out-Zeit fur Messung n_s := 0; Sprung zu S12 
von n_s wurde uberschritten 


T13 


Drehzahl n liegt vor Regler starten; Stellwert 

berechnen; Sprung zu S13 


T14 


Time-Out-Zeit fur Messung n := 0; Regler starten; 
von n wurde uberschritten Stellwert berechnen; 
und n_s = 0 Sprung zu S13 


T15 


instantan i Stellwert ausgeben; Sprung 

izu S14 


T1 6 instantan i Regler beenden; Sprung zu 

IS10 


T1 7 ! Time-Out-Zeit fur Messung Maximalen Stellwert 

von n wurde uberschritten ausgeben; Sprung zu S15 
; und n_s <> 0 


T18 instantan !RGL_ON beenden; Sprung 

zu S10 



Im Zustand S10 wird auf den Start des Reglers gewartet. 



Bei einem Start des Reglers, z.B. durch die Routine TIMERO-lnterrupt S639 aus 
Fig. 12, geschieht ein Sprung zum Zustand S1 1, und es wird auf die 
Solldrehzahl n_s gewartet. 

Falls ein Wert fur die Solldrehzahl n_s vorliegt, findet der Ubergang T1 1 zum 
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Zustand S12 statt. 

Wird jedoch in S1 1 eine Time-Out-Zeit uberschritten, ohne dass ein Wert fur die 
Solldrehzahl n_s vorliegt, so findet der Ubergang T12 zum Zustand S12 statt, in 
welchem Obergang T12 die Solldrehzahl n_s auf Null gesetzt wird. 

Im Zustand S12 wird auf die Drehzahl n des Motors M gewartet. Falls ein Wert 
fur n vorliegt, findet der Obergang T13 nach S13 statt, die Reglerfunktion RGL 
S628 wird gestartet, und ein neuer Stellwert RGL_VAL wird berechnet. 

Vom Zustand S13 findet ein instantaner Obergang T15 nach S14 statt, und der 
berechnete Stellwert RGL_VAL wird ausgegeben. 

Vom Zustand S14 findet ein instantaner Obergang T16 nach S10 statt, und es 
wird auf den neuen Start gewartet. 

Wird im Zustand S12 eine Time-Out-Zeit uberschritten, so hat der Motor die 
Drehzahl n = 0. 

Es werden bei n = 0 zwei Falle unterschieden. 1st auch die Solldrehzahl n_s = 0, 
so findet der Obergang T14 nach S13 statt, und die Regelung RGL S628 
berechnet einen neuen Stellwert RGL_VAL. 

1st jedoch die Drehzahl n = 0 und die Solldrehzahl n_s ungleich Null, so ist 
entweder der Motor M blockiert oder er soil gestartet werden. Es findet ein 
Ubergang T17 nach S15 statt, und ein maximaler Stellwert wird ausgegeben. 

Vom Zustand S1 5 findet ein instantaner Obergang T18 zum Zustand S10 statt, 
und es wird auf den nachsten Start gewartet. 

Fig. 21 zeigt ein Flussdiagramm fur eine an Fig. 20 angepasste Routine 
RGL_ON2 S624', also fur den Fall, dass auch n_s = 0 beriicksichtigt werden soli. 

In S500 wird uberpruft, ob die Solldrehzahlberechnungsroutine CALC_n_s 
S620 (Fig. 16) abgearbeitet ist, ob also eine Solldrehzahl n_s vorliegt. 
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Falls ja, so wird nach S506 gesprungen. 

Falls nein, so wird in S502 uberpruft, ob seit der letzten Messung eine Time-Out- 
Zeit t_TO_s uberschritten wurde. Hierzu wird die Differenz zwischen dem 
Zeitpunkt der letzten Messung t_END_J_s (vgl. Fig. 14) und dem momentanen 
Zeitpunkt des Timers TIMER1 berechnet und mit der Time-Out-Zeit t_TO_s 
verglichen. 

1st die Time-Out-Zeit t_TO_s noch nicht uberschritten, so wird zum Anfang S602 
des Funktionsmanagers (Fig. 8) gesprungen und weiter auf die Solldrehzahl n_s 
gewartet. 

1st die Time-Out-Zeit t_TO_s jedoch uberschritten, so wird in S504 die 
Solldrehzahl n_s auf Null gesetzt. Weiterhin wird der Zeitpunkt t_END_f_s der 
letzten Messung auf den momentanen Wert MTIMER1 von TIMER1 gesetzt, 
damit der TIMER1 nicht den Wert t_END_f_s uberrundet. Daraufhin wird zu 
S506 gesprungen. 

In S506 wird analog zu S500 uberpruft, ob ein Wert fur die Drehzahl n vorliegt. 

Falls ja, so wird in S514 die Regierfunktion RGL S628 (Fig. 18) durch Setzen 
des Funktionsregisterbits FCT_RGL auf 1 angefordert, und die Routine 
RGL_ON2 wird durch das Zurucksetzen von FCT_RGL_ON auf Null beendet. 

Liegt in S506 ein Wert fur die Drehzahl n nicht vor, so wird in S508 analog zu 
S502 uberpruft, ob seit der letzten Messung der Drehzahl n zum Zeitpunkt 
t_END_f die Time-Out-Zeit t_TO uberschritten wurde. 

Falls nein, so wird nach S602 (Fig. 8) gesprungen, und es wird weiter auf einen 
Wert fur die Drehzahl n gewartet. 

Bei einer Uberschreitung der Time-Out-Zeit t_TO wird in S510 uberpruft, ob die 
Solldrehzahl n s = 0 ist. 
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Falls ja, so wird nach S514 gesprungen, und die Reglerfunktion RGL S628 wird 
mit den Werten n = 0 und n_s = 0 aufgerufen. 

Falls nein, so ist entweder der Motor M blockiert, Oder er soli gerade gestartet 
werden. Daher wird in S512 das Register PWM.SW des PWM-Generators des 
uC23 auf den maximalen Stellwert RGL_MAX gesetzt. Der Wert t_END_f wird 
analog zu S504 auf den momentanen Timerwert t_TIMER1 gesetzt, urn einen 
Uberlauf zu vermeiden, und die Routine RGL_ON2 S624' wird durch Setzen von 
FCT_RGL_ON auf Null und Sprung zu S602 beendet. 

An der Reglerfunktion RGL S628 mussen bei dieser Variante keine weiteren 
Anderungen vorgenommen werden. 

Die Time-Out-Zeiten t_TO_s und t_TO mussen entsprechend den 
Anforderungen des Reglers und des Motors gewahlt werden. Z.B. kann man mit 
einer relativ kurzen Time-Out-Zeit dafur sorgen, dass der Motor unterhalb einer 
definierten minimalen Drehzahl abgeschaltet wird. Manche Motoren sind bei 
niedrigen Drehzahlen schwer zu regeln, z.B. Ottomotoren, weil sie dann zum 
Schwingen neigen, und es kann dann erwunscht sein, diese Drehzahlbereiche 
nicht zuzulassen. 

Ein typischer Wert von t_TO ist 1 00 ms, entsprechend einer Motordrehzahl von 
ca. 50 U/min. Ein Wert von 1000 ms wurde einer Drehzahl von ca 5 U/min 
entsprechen. Bei einem Elektromotor kann aber ein solch gro&er Wert zur 
thermischen Uberlastung der Endstufentransistoren (Transistoren 740, 744 in 
Fig. 29) fuhren. 



Parametrierung des Motors 

Alle bisher erlauterten Variablen konnen vom Hersteller vorgegeben werden. 
Man sagt, dass der Hersteller den Motor "parametriert". Die Variablen konnen in 
einem nichtfluchtigen Speicher, z.B. in einem ROM, Flash-ROM oder dem 
EEPROM 80 der Fig. 3, vorliegen, oder man kann sie z.B. durch Dip-Switches 
einstellen. Beim Start des Motors werden sie dann z.B. im Schritt INIT S602 (Fig. 
8) in das RAM des nC 23 geladen. 
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Weiterhin konnen die verwendeten Variablen ggf. uber den Bus B (Fig. 3) 
verandert werden. Uber diesen externen Bus B kann ggf. eine Anderung der 
Variablen im EEPROM 80 durchgefuhrt werden. Alternativ kann das EEPROM 80 
vor seiner Montage vom Hersteller programmiert werden. Dabei konnen auch 
andere Variablen programmiert werden, z.B. der Proportionalfaktor RGL_P des 
Reglers, der Integralfaktor RGLJ, und die Gesamtverstarkung des Reglers (Fig. 
18). Bei Verwendung verschiedener Motoren kann das sehr wichtig sein, um 
einen optimalen Antrieb zu erhalten. 

Besonders wichtig ist die Moglichkeit, die Variablen MOD_f, MOD_f_s und X 
beeinflussen zu konnen. Mit MOD_f und MOD_f_s ist es moglich, den Regler auf 
verschiedene Polzahlen der verwendeten Rotoren und unterschiedliche Arten 
von Sollfrequenzgebern 20 einzustellen. Wurde z.B. f__s von dem zweipoligen 
Rotor 732 und dem Hallgenerator 61 der Fig. 29 erzeugt, so wurde man 
MOD_f_s auf 2 (oder ggf. auch auf 4) einstellen, um ein erstklassiges Resultat 
des Regelvorgangs zu erhalten. 

Auf diese Weise kann dasselbe Programm fur unterschiedliche Motortypen 
verwendet werden, indem die Parameter an den verwendeten Motortyp und den 
verwendeten Sollwertgeber angepasst werden. Die Verwendung desselben 
Programms fur verschiedene Motortypen spart Produktions- und 
Entwicklungskosten, und der Hersteller kann sehr flexibel auf Kundenwunsche 
reagieren. Distributoren oder bevorzugten Kunden kann es auch gestattet 
werden, das EEPROM 80 selbst zu programmieren, z.B. bei Versuchen zur 
Optimierung eines Antriebs. Durch eine Kennwortfunktion kann eine 
unerwunschte Programmierung durch Benutzer verhindert werden. 

Die Parametrierung des Getriebefaktors X ermoglicht die Verwendung 
desselben Sollfrequenzgebers 20 fur mehrere Motoren, welche in einem festen 
Drehzahlverhaltnis zueinander laufen mussen, welches jedoch von Motor zu 
Motor unterschiedlich sein kann. Mit Hilfe des Getriebefaktors X ist z.B. eine 
andauernde Straffung wahrend des Transports einer Materialbahn (z.B. 
Kunststofffolien oder Stoff) moglich, indem bei einem ersten Motor ein 
Getriebefaktor X = 1,000 und bei einem zweiten, in Bewegungsrichtung 
vorderen Motor ein Getriebefaktor X = 1,001 gewahlt wird. Hierdurch dreht der 
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zweite Motor minimal schneller, was eine Straffung der transportierten Bahn 
bewirkt. 

Die Regelung mittels der Sollfrequenz f_s wird umso dynamischer, je hdher 
diese Frequenz ist. Andererseits wird mit einer hoheren Sollfrequenz auch der 
uC 23 starker durch Rechenvorgange belastet. Ein Verhaltnis zwischen 
Sollfrequenz f_s und Istfrequenz f von f_s / f > 5 / 1 hat sich fur Motoren, welche 
schnell auf Anderungen der Sollfrequenz reagieren sollen, als vorteilhaft 
erwiesen. Unter Frequenz wird dabei die Anzahl der Ereignisse pro Zeiteinheit 
verstanden, z.B. bei einem Hallsignal (Fig. 4) die Zahl der Flanken 110 pro 
Sekunde. 

Fig. 26 zeigt ein Beispiel fur die Verwendung dreier erfindungsgemaBer 
Motoren. Eine Sollfrequenz f_s von einem Frequenzgenerator 180 wird drei 
erfindungsgemaBen Motoren 181, 183 und 185 iiber eine Leitung 187 zugefiihrt. 
Der Rotor des Motors 181 ist zweipolig, der des Motors 183 vierpolig und der 
des Motors 185 sechspolig. Verschiedene Motoren sind z.B. notig, wenn an 
verschiedenen Stellen unterschiedlich leistungsstarke Motoren benotigt werden. 

In diesem Ausfuhrungsbeispiel sollen alle drei Motoren mit der gleichen, durch 
die Sollfrequenz vorgegebenen Drehzahl laufen. Hierzu werden z.B. die 
Getriebefaktoren X(181) des Motors 181, X(183) des Motors 183 und X(185) des 
Motors 185, auf X(181) = 1, X(183) = 2 und X(185) = 3 gesetzt. 

Fig. 27 zeigt schematisch ein Fotokopiergerat mit drei erfindungsgemaBen 
Motoren M1, M2 und M3, welche uber die Leitung 187 von einem 
Frequenzgenerator 180 eine Sollfrequenz f_s vorgegeben bekommen. Falls der 
Motor M2, welcher z.B. eine Walze antreibt, eine andere Drehzahl als die 
Motoren M1 und M3 benotigt, so kann dies uber einen Getriebefaktor X 
eingestellt werden. 

Fur ein solches Gerat ist es vorteilhaft, wenn ein Regler gemaB Fig. 20 
verwendet wird, mit dem die Drehzahl der Motoren mittels der Sollfrequenz f_s 
auf Null geregelt werden kann. 
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Fig. 28 zeigt ein weiteres Ausfuhrungsbeispiel mit drei Motoren M1, M2 und 
M3. Der Motor M1 gibt hierbei ein sogenanntes Tachosignal aus. Ein 
Tachosignal kann z.B. erzeugt werden, indem das Signal des 
Rotorstellungssensors 61 ausgegeben wird. Mit Hilfe des Tachosignals konnen 
weitere erfindungsgemaRe Motoren M2, M3 in einem festen Verhaltnis zu der 
Drehzahl des Motors M1 geregelt werden. So wird auch ohne einen speziellen 
Frequenzgenerator erreicht, dass die drei Motoren in einem festen 
Drehzahlverhaltnis zueinander laufen, weil der Motor M1 als Frequenzgenerator 
dient. 

Bei der Erfindung wird also eine Sollwertinformation, welche in der Frequenz 
eines Sollfrequenzsignals enthalten ist, einem jiC zugefuhrt. Ein Motor, fur den 
dieser Sollwert bestimmt ist, liefert seinerseits ein Frequenzsignal zuriick, 
welches als Information die Istdrehzahl dieses Motors enthalt. Dieses 
Frequenzsignal kann z.B. von einem Tachogenerator kommen, einem Resolver, 
einem motorinternen Sensor, z.B. einem Hallgenerator fur die Steuerung der 
Kommutierung des Motors, oder anderen Arten von Sensoren. 

Sollfrequenz und Istfrequenz werden fortlaufend und annahernd synchron im |iC 
erfasst und in drehzahlproportionale numerische Werte umgerechnet. Diese 
numerischen Werte konnen nun mit vorgegebenen Parametern manipuliert 
werden, gewohnlich durch Multiplikation oder Division. (Diese Parameter 
konnen z.B. in einem EEPROM gespeichert sein.) Man erhalt so z.B. ein 
Vielfaches der erfassten Sollfrequenz, oder einen Bruchteil der erfassten 
Sollfrequenz, oder ein Vielfaches der erfassten Istfrequenz, oder einen Bruchteil 
der erfassten Istfrequenz. Diese manipulierten Werte werden einem 
Drehzahlregler zugefuhrt, und auf diese Weise kann eine Getriebefunktion 
realisiert werden. Um die Regeleigenschaften anzupassen oder zu variieren, 
konnen aufterdem Regelparameter sehr leicht verandert werden, die das 
Regelverhalten des Systems beeinflussen. 

Die manipulierten Werte werden im Drehzahlregler miteinander verglichen, die 
Regeldifferenz wird aus ihnen gebildet, diese wird in einem Pl-Regler, oder 
einem PID-Regler, verarbeitet, wie das in S532 ausfuhrlich an einem Beispiel 
dargestellt ist, und der im Regler generierte Stellwert wird z.B. in ein PWM- 
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Register geschrieben. Ein entsprechendes PWM-Signal wird als Stellwert 
ausgegeben und beim beschriebenen Ausfuhrungsbeispiel uber ein RC-Filter 
65, 67 in ein analoges Gleichspannungssignal umgewandelt. Dieses wird einem 
Stellglied zugefuhrt welches die Energiezufuhr des Motors steuert. Der Motor 
liefert seinerseits eine vorgegebene Zahl von Impulsen Oder sonstigen Signalen 
("Ereignissen") an den zuruck, und diese liefern dem Regler eine exakte 
digitale Information uber die aktuelle Drehzahl des Motors. 

NaturgemaB sind im Rahmen der vorliegenden Erfindung vielfache 
Modifikationen moglich. Die Einstellung des Getriebefaktors X ist an vielen 
Stellen moglich, wie erlautert, und die Istfrequenz (entsprechend der 
Istdrehzahl) kann auf vielfaltige Weise erzeugt werden. 
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Patentanspruche 

1. Verfahren zum Regeln der Drehzahl eines Motors, 

- dem ein digitaler Drehzahlregler zugeordnet ist, und 

- der im Betrieb ein Istwertsignal fur die Drehzahl in Form eines 
Drehzahl-Frequenzsignals liefert, 

auf einen in Form eines Sollwert-Frequenzsignals vorgegebenen 

Drehzahl-Sollwert, 

mit folgenden Schritten: 

In einem ersten Zeitabschnitt wird aus dem Drehzahl- 
Frequenzsignal ein erster numerischer Frequenzwert ermittelt, 
welcher die Drehzahl des Motors charakterisiert; 
in einem zweiten Zeitabschnitt, welcher im wesentlichen zeitgleich 
mit dem ersten Zeitabschnitt ist, wird aus dem Sollwert- 
Frequenzsignal ein zweiter numerischer Frequenzwert ermittelt, 
welcher die Frequenz des Sollwert-Frequenzsignals charakterisiert; 
mittels erstem und zweitem numerischem Frequenzwert wird im 
digitalen Drehzahlregler die Drehzahl des Motors auf eine Drehzahl 
geregelt, welche dem Sollwert-Frequenzsignal nach einer 
vorgegebenen mathematischen Beziehung zugeordnet ist. 

2. Verfahren nach Anspruch 1 , bei welchem zur Ermittlung der 
numerischen Frequenzwerte eine Zeitmessung zwischen 
vorgegebenen Ereignissen des betreffenden Frequenzsignals 
vorgenommen wird. 

3. Verfahren nach Anspruch 2, bei welchem Flanken des betreffenden 
Frequenzsignals als Ereignisse dienen, zwischen welchen eine 
Zeitmessung stattfindet. 

4. Verfahren nach Anspruch 2 oder 3, bei welchem fur die 
Zeitmessung zur Ermittlung des ersten numerischen Frequenzwerts 
und fur die Zeitmessung zur Ermittlung des zweiten numerischen 
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Frequenzwerts dasselbe Zeitnormal verwendet wird. 

5. Verfahren nach einem der vorhergehenden Anspruche zur 

Bestimmung der Frequenz eines Frequenzsignals, welches bei 
konstanter Frequenz pro Zeiteinheit eine feste Anzahl von 
Ereignissen nach Art von Impulsen, Flanken oder dergleichen 
aufweist, 

mit folgenden Schritten: 

a) Zu einem ersten, vorgegebenen Zeitpunkt wird die Messung einer 
Frequenzinformation eingeleitet; 

b) ein zweiter Zeitpunkt wird ermittelt, an dem ein dem ersten, 
vorgegebenen Zeitpunkt folgendes Ereignis des Frequenzsignals 

auftritt; 

c) die Anzahl der auf den zweiten Zeitpunkt folgenden Ereignisse des 
Frequenzsignals wird erfasst; 

d) zu einem dritten, vorgegebenen Zeitpunkt wird die Beendigung der 
Messung der Frequenzformation eingeleitet; 

e) ein vierter Zeitpunkt wird ermittelt, an dem ein dem dritten, 
vorgegebenen Zeitpunkt folgendes Ereignis des Frequenzsignals 

auftritt; 

f) aus dem zeitlichen Abstand zwischen zweitem Zeitpunkt und viertem 
Zeitpunkt sowie der Anzahl der Ereignisse des Frequenzsignals 
zwischen diesen Zeitpunkten wird die Frequenzinformation 
berechnet. 



6. Verfahren nach Anspruch 5, bei welchem fur die Ermittlung des vierten 
Zeitpunkts als dem dritten, vorgegebenen Zeitpunkt folgendes Ereignis 
das nachstfolgende Ereignis des Frequenzsignals gewahlt wird. 

7. Verfahren nach Anspruch 5, bei welchem fur die Ermittlung des vierten 
Zeitpunkts als dem dritten, vorgegebenen Zeitpunkt folgendes Ereignis 
dasjenige nachste Ereignis des Frequenzsignals gewahlt wird, bei 
welchem die Anzahl der Ereignisse seit dem zweiten Zeitpunkt gleich 
einem Produkt a • N ist, wobei a und N ganze Zahlen sind, von denen die 
eine mindestens gleich 1 und die andere mindestens gleich 2 ist. 
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8. Verfahren nach Anspruch 7, bei welchem bei einem Drehzahl- 
Frequenzsignal (f) die Zahl N einer festen Anzahl von Ereignissen pro 
Umdrehung des Rotors entspricht. 

9. Verfahren nach einem Oder mehreren der vorhergehenden Anspruche 5 
bis 8, bei welchem fortlaufend Messungen gemaB Anspruch 5 
durchgefuhrt werden. 

10. Verfahren nach Anspruch 9, bei welchem die ersten, vorgegebenen 
Zeitpunkte aufeinanderfolgender Messungen vorgegebene zeitliche 
Abstande (T_A) aufweisen, 

und bei welchem die dritten, vorgegebenen Zeitpunkte jeweils einen im 
wesentlichen konstanten zeitlichen Abstand von den zugeordneten 
ersten t vorgegebenen Zeitpunkten haben. 

1 1 . Verfahren nach Anspruche 9 oder 10, bei welchem der dritte, 
vorgegebene Zeitpunkt einer ersten Messung dem ersten, 
vorgegebenen Zeitpunkt einer darauffolgenden zweiten Messung 
entspricht. 

12. Verfahren nach Anspruche 11, bei welchem der vierte Zeitpunkt einer 
ersten Messung dem zweiten Zeitpunkt einer darauffolgenden zweiten 
Messung entspricht. 

13. Verfahren nach einem oder mehreren der vorhergehenden Anspruche, 
bei welchem zum Generieren einer Frequenzinformation eine Division 
der Anzahl (N) der Ereignisse des Frequenzsignals zwischen dem 
zweiten und dem vierten Zeitpunkt durch den zeitlichen Abstand (At) 
zwischen diesen beiden Zeitpunkten vorgenommen wird. 

14. Verfahren nach Anspruch 13, bei welchem die Drehzahlinformation 
durch eine Multiplikation mit einem konstanten Faktor parametriert wird. 

15. Verfahren nach Anspruch 14, bei welchem der konstante Faktor so 
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gewahlt ist, dass die Drehzahlinformation im wesentlichen einer 
physikalischen Drehzahl entspricht, z.B. U/min oder U/sec. 

16. Verfahren nach einem der Anspruche 13 bis 15, bei welchem die 
Division mit einem der Anzahl der Impulse zwischen dem zweiten und 
dem vierten Zeitpunkt proportionalen Zahler (Englisch: numerator) und 
einem der Zeitdauer zwischen zweitem und vierten Zeitpunkt 
proportionalen Nenner (Englisch: denominator) als Ergebnis eine 
ganzzahlige Frequenzinformation und einen Rest ergibt, und bei 
welchem der sich ergebende Rest durch Addition zum Zahler (Englisch: 
numerator) der nachfolgenden Messung berucksichtigt wird. 

Beispiel fur eine ganzzahlige Division: 7/3 = 2 Rest 1 . 7 ist der Zahler (numerator), 3 ist der 
Nenner (denominator), und 1 ist der Rest (remainder). Das Resultat dieser Division ist 2. 

17. Verfahren zur Gewinnung einer Information uber die Drehzahl eines 
rotierenden, im folgenden Rotor genannten Objekts, nach einem oder 
mehreren der vorhergehenden Anspriiche, 

mit einer Anordnung zur Erzeugung eines Drehzahlsignals (f), welches 
pro Rotorumdrehung mindestens ein Ereignis nach Art eines Impulses, 
einer Signalflanke oder dgl. aufweist, und mit folgenden Schritten: 

a) Wahrend einer ersten Messperiode (T_M1) wird die Zahl (N) der 
Ereignisse des Drehzahlsignals (f) erfasst; 

b) die zeitliche Dauer (At) der ersten Messperiode (T_M1) wird erfasst; 

c) durch eine ganzzahlige Division ("div"), bei der die Zahl der 
Ereignisse wahrend der ersten Messdauer (T_M1) im Zahler 
(Englisch: numerator) und die zeitliche Dauer der ersten Messperiode 
(T_M1) im Nenner (Englisch: denominator) steht, werden als 
Ergebnis eine erste ganzzahlige Drehzahlinformation und ein Rest 
erzeugt (Fig. 15: S372; Fig. 16: S472); 

c) bei der Auswertung einer anschliessenden Messung wird dieser Rest 
(REM_n_OLD; REM_n_s_OLD) bei der dann stattfindenden 
ganzzahligen Division durch Addition zum Zahler (Englisch: 
numerator) berucksichtigt. 

18. Verfahren nach Anspruch 17, bei welchem die Zahl (N) der Ereignisse 
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vor der ganzzahligen Division (S372; S472) mit einem konstanten Faktor 
(2 A h; 2 A h_s) multipliziert wird, welcher groRer ist ais 1, urn ein im 
Verhaltnis zum Rest (REM_n; REM_n_s) groRes Resultat der 
ganzzahligen Division zu erhalten. 

19. Verfahren nach Anspruch 18, bei welchem der konstante Faktor eine 
Zweierpotenz (2 A h; 2 A h_s) ist. 

20. Verfahren nach Anspruch 19, bei welchem der Exponent (h; h_s) der 
Zweierpotenz eine einstellbare Variable ist. 

21 . Vorrichtung zur Durchfuhrung eines Verfahrens nach einem der 
vorhergehenden Anspruche, 

bei welchem zur Gewinnung einer Information uber die Drehzahl eines 
rotierenden, im folgenden Rotor (32; 32'; 32") genannten Objekts 
ein Sensor (61) vorgesehen ist, welcher ein Drehzahl-Signal (f) liefert, 
das pro Umdrehung des Rotors (32; 32'; 32") eine vorgegebene Zahl von 
Ereignissen (Fig. 10: 110) aufweist, 

mit einer Quelle (23) fur Steuersignale (Fig. 10: 191, 193, 195), 

mit einem Zahler (INT_CNT_f) fur Ereignisse (110) des Drehzahl-Signals 

(0, 

mit einer programmgesteuerten Vorrichtung (23) zum Auswerten der 
genannten Signale, welcher ein Programm zugeordnet ist, das zur 
Ausfuhrung folgender Schritte ausgebildet ist: 

a) Durch ein erstes Steuersignal (Fig. 10: 191) wird die Messung einer 
Drehzahlinformation eingeleitet; 

b) ein erster Zeitpunkt (Fig. 10: 197) wird ermittelt, an dem ein dem 
ersten Steuersignal (Fig. 10: 191) folgendes Ereignis (110) des 
Drehzahl-Signals (f) auftritt; 

c) die Anzahl der folgenden Ereignisse (110) des Drehzahl-Signals (f) 
wird durch den Zahler (INTJ3NTJ) fur Ereignisse (110) des 
Drehzahl-Signals (f) erfasst; 

d) durch ein zweites Steuersignal (Fig. 10: 193) wird die Beendigung 
der Messung der Drehzahlinformation eingeleitet; 

e) ein zweiter Zeitpunkt (Fig. 10: 199) wird ermittelt, an dem ein dem 
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zweiten Steuersignal (Fig. 10: 193) folgendes Ereignis des Drehzahl- 
Signals (f) auftritt; 

f) aus dem zeitlichen Abstand (Fig. 10: At_MEAS_f(197-199)) zwischen 
erstem Zeitpunkt (Fig. 10: 197) und zweitem Zeitpunkt (Fig. 10: 199) 
sowie der Anzahl (N) der Ereignisse (110) des Drehzahl-Signals (f) 
zwischen diesen beiden Zeitpunkten wird eine Drehzahlinformation 
(n) berechnet. 

22. Vorrichtung nach Anspruch 21 , bei welcher der Geber fur die 
Steuersignale einen Timer (TIMERO) aufweist. 

23. Vorrichtung nach Anspruch 22, bei welcher der Timer (TIMERO) dazu 
ausgebildet ist, als Steuersignale Interrupt-Vorgange (TIMERO-lnterrupt) 
auszulosen. 

24. Vorrichtung nach einem Oder mehreren der Anspruche 21 bis 23, bei 
welcher zur Messung des zeitlichen Abstands zwischen erstem und 
zweitem Zeitpunkt ein Timer (TIMER1) vorgesehen ist. 

25. Vorrichtung nach Anspruch 24, bei welcher der Timer (TIMER1) zur 
Messung des zeitlichen Abstands zwischen erstem und zweitem 
Zeitpunkt als Ringzahler ausgebildet ist. 

26. Vorrichtung nach Anspruch 25, bei welcher der Ringzahler (TIMER1) 
fortlaufend zahlt, und das Ende einer abgeschlossenen Messung mit 
dem Beginn einer neuen Messung im wesentlichen identisch ist. 

27. Vorrichtung nach einem oder mehreren der Anspruche 21 bis 26, bei 
welcher als Drehzahl-Signal ein Signal eines elektronisch kommutierten 
Motors dient. 

28. Vorrichtung nach einem oder mehreren der Anspruche 21 bis 27, bei 
welcher der Zahler (INT_CNT_f) fur Ereignisse (110) des Drehzahl- 
Signals (f) 

in der programmgesteuerten Vorrichtung (23) vorgesehen ist. 
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29. Motor, bei welchem die Drehzahl durch ein Sollwertsignal in Form einer 
Frequenz (f_s) dadurch auf Null regelbar ist, dass diesem Sollwertsignal 
der Frequenzwert Null gegeben wird. 

30. Verfahren zum Regeln der Drehzahl eines Motors, welcher einen 
Rotor aufweist, und dem ein Drehzahlregler zugeordnet ist, um die 
Drehzahl dieses Rotors zu regeln, 

mit einern Drehzahl-Frequenzsignal (f), welches eine zur Drehzahl 
des Rotors proportionale Frequenz aufweist, 
mit einem Sollwert-Frequenzsignal (f_s), 

wobei die Drehzahl des Rotors so geregelt wird, dass die Frequenz 
des Drehzahl-Frequenzsignals (f) und die Frequenz des Sollwert- 
Frequenzsignals (f_s) in einem vorgegebenen Verhaltnis (y/z) 
zueinander stehen. 

31 . Verfahren nach Anspruch 30, bei welchem das Verhaltnis zwischen 
den Frequenzen f und f_s durch mindestens einen Parameter 
beeinflusst wird. 

32. Verfahren nach Anspruch 31, bei welchem das Verhaltnis zwischen 
den Frequenzen f und f_s im Regler durch mindestens einen Faktor 
(X; Y) vorgegeben wird. 

33. Verfahren nach Anspruch 32, bei welchem der mindestens eine 
Parameter in einem nichtfluchtigen Speicher gespeichert wird. 

34. Verfahren zur Frequenzermittlung bei einer Mehrzahl von Signalen (f 
und f_s), welche Signale Frequenzinformationen nach Art von Impulsen, 
Flanken oder dergleichen aufweisen, mit folgenden Schritten: 

a) Fur mindestens zwei dieser Signale wird zu einem ersten, 
vorgegebenen Zeitpunkt die Messung ihrer Frequenz eingeleitet; 

b) fur jedes dieser Signale wird ein zweiter Zeitpunkt ermittelt, an dem 
eine dem ersten, vorgegebenen Zeitpunkt folgende 
Frequenzinformation dieses Signals auftritt; 
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c) die Zahl der auf den zweiten Zeitpunkt folgenden 
Frequenzinformationen jedes dieser Signale wird getrennt erfasst; 

d) zu einem dritten, vorgegebenen Zeitpunkt wird fur diese Signale die 
Beendigung der Messung der Frequenz eingeleitet; 

e) fur jedes dieser Signale wird ein vierter Zeitpunkt ermittelt, an dem 
eine dem dritten, vorgegebenen Zeitpunkt folgende 
Frequenzinformation dieses Signals auftritt; 

f) aus dem zeitlichen Abstand zwischen zweitem Zeitpunkt und viertem 
Zeitpunkt sowie der Zahl der Frequenzinformationen des 
betreffenden Signals zwischen diesen Zeitpunkten wird fur jedes der 
gemessenen Signale eine seine Frequenz charakterisierende GroBe 
bestimmt. 

35. Verfahren nach Anspruch 34, bei welchem fur die Ermittlung des vierten 
Zeitpunkts als dem dritten, vorgegebenen Zeitpunkt folgende 
Frequenzinformation die nachstfolgende Frequenzinformation des 
betreffenden Signals gewahlt wird. 

36. Verfahren nach Anspruch 34, bei welchem fur die Ermittlung des vierten 
Zeitpunkts als dem dritten, vorgegebenen Zeitpunkt folgende 
Frequenzinformation diejenige nachste Frequenzinformation des 
betreffenden Signals gewahlt wird, bei welcher die Anzahl der 
Frequenzinformationen seit dem zweiten Zeitpunkt einem ganzzahligen 
Vielfachen einer ganzen Zahl aus der Reihe 2, 3, 4, ... entspricht. 

37. Verfahren nach einem der Anspruche 34 bis 36, bei welchem fortlaufend 
Messungen vorgenommen werden und die dritten, vorgegebenen 
Zeitpunkte jeweils einen im wesentlichen konstanten zeitlichen Abstand 
(T_A) von den zugeordneten ersten, vorgegebenen Zeitpunkten haben. 

38. Verfahren nach Anspruch 37, bei welchem der dritte, vorgegebene 
Zeitpunkt der Messung eines Signals dem ersten, vorgegebenen 
Zeitpunkt einer anschliefeenden Messung entspricht. 



39. Verfahren nach Anspruch 37 Oder 38, bei welchem der vierte Zeitpunkt 
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einer Messung dem zweiten Zeitpunkt einer anschlieRenden Messung 
desselben Signals entspricht. 

40. Verfahren nach einem der Anspruche 34 bis 39, bei welchem die ersten, 
vorgegebenen Zeitpunkte fur die Einleitung der Messung der Mehrzahl 
von Signalen im wesentlichen identisch sind. 

41. Verfahren nach einem der Anspruche 34 bis 40, bei welchem die dritten, 
vorgegebenen Zeitpunkte fur die Einleitung der Beendigung der 
Messung der Mehrzahl von Signalen im wesentlichen identisch sind. 
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REM_n_s_OLD := REM_n_s 
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FCT_CALC_n_s := 0 
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RGL_PROP : 


= RGL_DIFF * RGL_P 


RGL_INT := RGL 


INT 


+ RGL_DIFF * RGL — I 


RGL_VAL := 


RGL, 


.PROP + RGL_INT 
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Fig. 18 
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n_s : = 0 
t_END__f_s := t_TIMERl 



-S506 



S508 




S512 



JUL 



FCT_RGL := 1 
FCT RGL ON : = 0 



PWM_SW := RGL_MAX 
t_END_f := t_TIMERl 
FCT_RGL_ON := 0 



C 



FCT MAN 



"J 



S602 



Fig. 21 



WO 01/22095 





PCT/EP00/07622 




WO 01/22095 





PCT/EPOO/07622 



in 



CO 



00 
CM 



C\J 



CD 

CM 



in 

CM 



CM 



CO 
CM 



CM 
CM 



CM 



CO 



o 

CM 



24/27 



"O 

o 
E 



00 



CO 



CM 



cm 
i 

CO 
CM 



CD 



LO 



CO 

Tf CM 
i 

00 

CO t- 

CM 



LO 
CVJ 

Ll 





CO 


t 


t 


o 


CM 


CO 


CO 







WO 01/22095 



PCT/EP00/07622 



25127 




WO 01/22095 



PCT/EPOO/07622 



26/27 





